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E-MAIL SOFTWARE AND METHOD AND SYSTEM FOR 
DISTRIBUTING ADVERTISEMENTS TO CLIENT DEVICES 
5 THAT HAVE SUCH E-MAIL SOFTWARE INSTALLED THEREON 



COPYRIGHT NOTICE 

10 A portion of the disclosure of this patent document contains material which is subject 

to copyright protection. The copyright owner has no objection to the facsimile reproduction 
by any one of the patent document or patent disclosure as it appears in the Patent and 
Trademark Office patent file or records, but otherwise reserves all copyright rights 
whatsoever. 

15 

BACKGROUND OF THE INVENTION 

The present invention relates generally to the field of electronic mail ("e-mail") 
20 software and systems. More particularly, the present invention is related to advertiser- 
supported e-mail software for delivering advertisements to client computers having this 
advertiser-supported e-mail software installed thereon. 

This application is based on Provisional Patent Application No. 60/ 169,622, which 
25 was filed on December 8, 1999. This Provisional Patent Application is incorporated herein by 
reference in its entirety. 

Electronic mail ("e-mail") has become a ubiquitous form of communication in recent 
years. In general, e-mail works as follows. E-mail software is installed on a client device, 
30 e.g,, a personal computer (PC), equipped or configured for communications with a 
multiplicity of other client devices via a communications network. Access to the 
communications network can be provided by a communications network service provider, 
e.g., an Internet Service Provider (ISP) and/or a proprietary network e-mail service provider, 
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with whom the user establishes one or more e-mail accounts, each identified by a unique e- 
mail address, e.g., president @ whitehouse. gov. The e-mail software, e.g., the e-mail client, 
enables a user of the client device to compose e-mail messages, to send e-mail messages to 
other client devices via the communications network, and to read e-mail messages received 
5 from other client devices via the communications network. A user can send e-mail messages 
to multiple recipients at a time, which capability is sometimes referred to using a mailing list 
or, in extreme cases, bulk mailing. The typical e-mail client supports Post Office Protocol 
Version 3 (POP3), Simple Mail Transfer Protocol (SMTP), Internet Mail Access Protocol, 
Version 4 (IMAP4), and/or Multipurpose Internet Mail Extensions (MIME). 

10 

Each ISP and each proprietary network e-mail service provider independently 
operates and controls an e-mail communication system (or, simply, "e-mail system"). These 
independently-operated e-mail systems are bi-directional store-and-forward communication 
systems that are interconnected to one another via the Internet. Each e-mail system generally 

15 includes a number of e-mail servers that store inbound and outbound e-mail messages and 
then forward them, route them, or simply make them available to the users/intended 
recipients. Different e-mail systems are operated and controlled by independent control 
entities. With the advent of the Internet, the user is not restricted to a single system providing 
both an incoming e-mail server (or server cluster) and an outgoing e-mail server (cluster), i.e., 

20 both the incoming and outgoing e-mail servers under the control of a single entity. Most e- 
mail clients, other than proprietary e-mail systems such as AOL and JUNO, can be 
configured to receive e-mail from an incoming e-mail server (cluster) controlled by a first 
entity and an outgoing email server (cluster) controlled by a second, totally independent 
entity. It will be appreciated that most casual email users download from and upload to 

25 respective servers operated by a single entity. 

Generally, when a user desires to send e-mail messages, or to check for received 
messages (which operations can occur automatically according to a prescribed schedule), 
the e-mail software is activated. Upon being activated, the e-mail software: 
30 • effects a connection or communications session with the host ISP or e-mail service 

provider via a prescribed communication link by invoking a prescribed 
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communications mechanism, e.g., a dial-up modem, an ISDN connection, a DSL or 
ADSL connection, etc.; 

• electronically transmits or transports any e-mail messages desired to be sent to the e- 
mail server system operated by the host ISP or e-mail service provider, e.g., via an 

5 SMTP server; 

• receives any inbound e-mail messages forwarded to the client device by the host ISP 
or e-mail service provider, e.g., via a POP3 or IMAP4 server; and 

• stores any received e-mail messages in a prescribed memory location within the client 
device, e.g., at either the default location established by the e-mail client or a user- 

10 selected location. 

Exemplary e-mail software is the commercially available e-mail software marketed by 
the present assignee, QUALCOMM INCORPORATED, under the registered trademarks 
EUDORA PRO® and EUDORA LIGHT® (hereinafter sometimes referred to generically as 

15 "Eudora"). In general, the EUDORA PRO e-mail software provides the user with a "full 
feature set," and the EUDORA LIGHT e-mail software provides the user with a "reduced 
feature set" that is a subset of the "full feature set" provided by the EUDORA PRO e-mail 
software. The EUDORA PRO e-mail software (the previous version of which is referred to 
as "EP4" in this document) must be paid for by the user (or by someone else on behalf of the 

20 user), and can thus be regarded as "Pay ware", whereas the EUDORA LIGHT e-mail software 
is provided free of charge to registered users, and thus, can be regarded as "Freeware." Each 
of the client devices that has any version of Eudora installed thereon can be regarded as a 
"Eudora client." Presently, there is a very large installed base of Eudora clients. 

25 The present assignee, QUALCOMM INCORPORATED, has recently released a new 

version of its popular EUDORA e-mail software that is popularly known as EUDORA 
Adware (hereinafter sometimes referred to simply as "Adware"). This new Adware version 
of Eudora is contained within, i.e., is an integral part of, a new Eudora software product that 
contains the previously-referenced Payware and Freeware versions of Eudora. In general, 

30 each version of Eudora contained within this Eudora product release constitutes a separate 
operating mode of a single software product. Advantageously, the Adware Version of 
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Eudora Pro® can be activated or switched between modes either automatically, in accordance 
with prescribed criteria or conditions, or manually, in accordance with prescribed user 
actions, e.g., registration, payment, selection, etc. This new Adware version of Eudora and 
the multi-moded Eudora e-mail software product that contains the same were motivated by a 

5 desire on the part of the present assignee to provide users with the "full feature set" afforded 
by the Payware version of Eudora free of charge to the users, by means of distributing 
advertisements paid for by advertisers to Eudora clients, thereby effectively shifting the 
source of payment/revenue from the users to the advertisers. Thus, this new Eudora software 
product can be regarded as "advertiser-supported" or "advertiser-subsidized" or simply 

10 "sponsored" software. 

Most Internet service providers (ISPs) and e-mail service providers charge users a flat 
monthly subscription fee, although some providers still charge users based on usage, e.g., 
additional charges for on-line time beyond a prescribed level. However, there exists a 
15 population of users who desire to have basic e-mail service, but who do not require or want to 
pay for Internet access. A few companies have addressed the needs of this market segment 
by providing free e-mail service to users/subscribers who agree to receive advertisements 
along with their received e-mail messages. In this way, the advertisers support or sponsor the 
free e-mail service. 

20 

Based upon the relevant literature, it appears that the first company to propose and 
offer such a free e-mail service was FreeMark Communications (a.k.a. "ProductView 
Interactive"). The FreeMark system and method for providing free e-mail service is disclosed 
in PCT published patent application International Publication Number WO 96/24213, having 

25 a priority date of February 1, 1995, based on U.S. Application Serial Number 08/382,118, 
naming as inventors Marv Goldschmitt and Robert A. Young. The disclosure of this 
published PCT patent application is expressly incorporated herein by reference. In short, this 
free e-mail system was subsidized by advertisers that appended advertisements as 
attachments, e.g., graphical interchange format (GIF) image file attachments, to e-mail 

30 messages transmitted to subscribers. The advertisements were stored on the subscriber's 
computer for viewing while the subscriber was off-line reading the received e-mail messages. 
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In some of their promotional literature, FreeMark referred to the appended advertisements as 
"postage stamps". In FreeMark' s literature, each message received by the subscriber was 
depicted as an envelope bearing a postage stamp; the postage stamp was the advertisement. 

5 Subsequently, a company by the name of Juno Online Services, L.P. (hereinafter 

simply "JUNO") introduced a free e-mail service. The JUNO system and method for 
providing free e-mail service is disclosed in U.S. Patent Number 5,809,242, which issued to 
Marsh et aL on December 8, 1998, the disclosure of which is also expressly incorporated 
herein by reference. With the proprietary JUNO e-mail system, a plurality of advertisements 

10 are downloaded to subscribers when they connect to the proprietary JUNO e-mail server 
system to send and/or receive e-mail messages, with the advertisements being stored locally 
on the subscriber's computer for display when the subscriber is off-line composing or reading 
e-mail messages, i.e., when the subscriber activates Juno e-mail software previously installed 
on the subscriber's computer. The locally stored advertisements are displayed under the 

15 control of a display scheduler resident on the subscriber's computer, to thereby enable the 
advertisements to be rotated or changed in a dynamic manner. This results in a continuously- 
changing display of advertisements being presented to the subscriber. Various other aspects 
and features of the proprietary JUNO e-mail system are disclosed in U.S. Patent Number 
5,838,790, which issued to McAuliffe et al on November 17, 1998, and in U.S. Patent 

20 Number 5,848,397, which issued to Marsh et al on December 8, 1998; the disclosures of both 
of these patents are also expressly incorporated herein by reference. 

With both the FreeMark and JUNO proprietary free e-mail systems, both the 
advertisements and the e-mail messages are stored on a single e-mail system (e.g., JUNO 

25 stores both on a single, unique server which is assigned (bound) to the user when he/she first 
signs up for service), and are distributed to subscribers under the direction of a common 
control entity that is controlling all part of the e-mail system. While this may be a desirable 
system architecture for providing free e-mail service, it is not a suitable system architecture 
for a system whose purpose is to distribute advertiser-supported e-mail software that is e-mail 

30 system-independent, i.e., which is not tied to a particular proprietary e-mail service provider 
but, rather, supports public standards, e.g., POP3, SMTP, IMAP4, etc. Moreover, the free e- 



-5- 



[PA000373] 

mail system architecture is not suitable for the many people who maintain multiple e-mail 
accounts, e.g., business and personal e-mail accounts. As mentioned previously, the present 
inventors were motivated by a desire to provide a system and method for distributing 
advertisements to Eudora clients in order to generate advertising revenues that would allow a 
5 fully-featured version of the Eudora e-mail software to be widely distributed free of charge to 
end-users. Moreover, the present inventors were motivated by a desire to provide e-mail 
software that is both universal and e-mail system-independent, i.e., it is not tied to any 
particular proprietary e-mail service or service provider. 

10 Accordingly, the present inventors have developed a novel multi-moded Eudora e- 

mail software product that contains the Payware, Freeware and Adware, and have also 
devised a novel system and method for distributing advertisements to clients equipped with 
this new software product. As will become fully apparent hereinafter, the purpose and 
architecture of this novel system are radically different than that of the proprietary FreeMark 

15 and JUNO e-mail systems. In this regard, the multi-moded Eudora e-mail software product, 
and the novel system and method for distributing advertisements to clients equipped with this 
new software product, embraces a number of different inventions that will become fully 
apparent from the following disclosure and the documents referenced therein. 

20 SUMMARY OF THE INVENTION 

Based on the above and foregoing, it can be appreciated that there presently exists a 
need in the art for a subsidized e-mail client which overcomes the above-described 
deficiencies. The present invention was motivated by a desire to overcome the drawbacks 
25 and shortcomings of the presently available technology, and thereby fulfill this need in the 
art. 

In one of its aspects, the present invention encompasses e-mail software which 
incorporates an automatic advertisement download function for automatically downloading 
30 advertisements to be displayed when the e-mail software is activated, for the purpose of 
subsidizing the full e-mail software product (e.g., to provide a "Freeware" version of the e- 
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mail software product to end-users), wherein the e-mail software is e-mail system- 
independent. Preferably, the e-mail software is a stand-alone product which is universal, i.e., 
works in conjunction with virtually any e-mail service provider or e-mail system, including 
those service which comply with open standards. The present invention also encompasses a 
5 system and method for automatically distributing advertisements to a multiplicity of client 
devices which have this e-mail software installed thereon. 

According to one aspect, the present invention provides an e-mail client for receiving 
and sending e-mail messages to at least one of a plurality of e-mail servers operated by 
10 respective e-mail operators, wherein the e-mail client receives at least one ad from an ad 
server operated by a control entity different than the control entity operating the one or more 
e-mail systems. 

According to another aspect, the present invention provides a recording medium 
15 storing e-mail client software for instantiating an e-mail client which receives e-mail 
messages from and sends e-mail messages to at least one of a plurality of e-mail servers 
operated by their respective e-mail operators, wherein the e-mail client automatically receives 
ads from an ad server which operates independent of the e-mail servers. 

20 According to still another aspect, the present invention encompasses a method of 

operating an e-mail client, provided by an ad server operator, compatible with a plurality of 
independently operated e-mail servers, including ones based on open e-mail standards. 
Preferably, the method includes steps for periodically at least one of sending and receiving e- 
mail from selected ones of the e-mail servers, periodically receiving ads from the ad server 

25 operator, and displaying the received ads responsive to instructions provided by the ad server 
operator. 

According to a still further aspect, the present invention provides an e-mail system 
including an incoming e-mail server storing incoming e-mail messages addressed to a 
30 plurality of users, an outgoing e-mail server for forwarding or routing outgoing e-mail 
messages generated by the users, and an ad server operating independently of the e-mail 
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server, and a plurality of e-mail clients operated by respective users. Preferably, each of the e- 
mail clients checks for respective e-mail messages stored on the incoming e-mail server, 
transmits any outgoing e-mail messages stored on the e-mail client to the outgoing e-mail 
server, and downloads available ads from the ad server while the e-mail client is online. 

5 

In one aspect, the present invention provides software, for use on a client device that 
is configured for communications with at least one remote source of advertisements via a 
communications network, which instantiates an advertisement download function that 
downloads advertisements from the at least one remote source, during one or more 

10 advertisement download sessions, an advertisement storage function that stores the 
downloaded advertisements on a storage medium associated with the client device, an 
advertisement display function that effects display of at least selected ones of the stored 
advertisements on a display associated with the client device, an audit function that compiles 
ad-related statistical data relating to the downloaded advertisements, wherein the ad-related 

15 statistical data includes display event-related data regarding advertisements that were 
displayed during a prescribed audit interval, and an audit data transmit function that transmits 
the ad-related statistical data to a prescribed server system. Advantageously, the audit data 
transmit function generates a send audit data display window that requests the user's 
permission to transmit the ad-related statistical data to the prescribed server system, and the 

20 audit data transmit function transmits the ad-related statistical data only in response to a user's 
grant of permission to do so. 

In another aspect, the present invention provides software for use on a client device 
that is configured for communications with at least one remote source of advertisements via a 

25 communications network. Preferably, the software instantiates an advertisement download 
function that downloads advertisements from the at least one remote source, during one or 
more advertisement download sessions, an advertisement storage function that stores the 
downloaded advertisements on a storage medium associated with the client device, an 
advertisement display function that effects display of at least selected ones of the stored 

30 advertisements on a display associated with the client device, an audit function that compiles 
audit data including software usage data reflecting usage of the software by the user during a 
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prescribed audit interval, and an audit data transmit function that transmits the audit data to a 
prescribed server system. In an exemplary case, the audit data transmit function generates a 
send audit data display window that requests the user's permission to transmit the audit data 
to the prescribed server system, and the audit data transmit function transmits the audit data 
5 only in response to a user's grant of permission to do so. 

In a further aspect, the present invention provides software, for use on a client device 
that is configured for communications with at least one remote source of advertisements via a 
communications network, instantiating an advertisement download function that downloads 

10 advertisements from the at least one remote source, during one or more advertisement 
download sessions, an advertisement storage function that stores the downloaded 
advertisements on a storage medium associated with the client device, an advertisement 
display function that effects display of at least selected ones of the stored advertisements on a 
display associated with the client device, an audit function that compiles audit data including 

15 software usage data reflecting features of the software used by the user during a prescribed 
audit interval, an audit data transmit function that transmits the audit data to a prescribed 
server system. Preferably, the audit data transmit function generates a send audit data display 
window that requests the user's permission to transmit the audit data to the prescribed server 
system, and transmits the audit data only in response to a user's grant of permission to do so. 

20 

In yet another aspect, the present invention provides software, for use on a client 
device that is configured for communications with at least one remote source of 
advertisements via a communications network, instantiates functions including an 
advertisement download function that downloads advertisements from the at least one remote 

25 source, during one or more advertisement download sessions, an advertisement storage 
function that stores the downloaded advertisements on a storage medium associated with the 
client device, an advertisement display function that effects display of at least selected ones 
of the stored advertisements on a display associated with the client device, an audit function 
that compiles at least two categories of audit data, including software usage data reflecting 

30 features of the software by the user during a prescribed audit interval, and ad-related 
statistical data relating to the downloaded advertisements, and an audit data transmit function 
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that transmits one or more categories of the audit data to a prescribed server system. The ad- 
related statistical data advantageously includes display event-related data regarding 
advertisements that were displayed during the prescribed audit interval. Preferably, the audit 
data transmit function generates a send audit data display window that requests the user's 
5 permission to transmit each category of the audit data to the prescribed server system, and the 
audit data transmit function transmits only the category(ies) of the audit data for which the 
user has granted permission to transmit. 

In still another aspect, the present invention provides software for use on a client 
10 device that is configured for communications with at least one remote source of 
advertisements via a communications network, which software instantiates an advertisement 
download function that downloads advertisements from the at least one remote source, during 
one or more advertisement download sessions, an advertisement storage function that stores 
the downloaded advertisements on a storage medium associated with the client device, an 
15 advertisement display function that effects display of at least selected ones of the stored 
advertisements on a display associated with the client device, an audit function that compiles 
a plurality of categories of audit data regarding activities of the user and/or client device 
during a prescribed audit interval, and an audit data transmit function that transmits one or 
more categories of the audit data to a prescribed server system. In an exemplary case, the 
20 audit data transmit function generates a send audit data display window that requests the 
user's permission to transmit each category of the audit data to the prescribed server system, 
and transmits only the category(ies) of the audit data for which the user has granted 
permission to transmit. 

25 Many other features, aspects, uses, applications, advantages, modifications, 

variations, and alternative embodiments of the foregoing inventive concepts will become 
apparent from the technical documentation that follows. This technical documentation 
constitutes an integral part of this application for all purposes. Moreover, additional 
inventive concepts that have not been discussed above are disclosed in this technical 

30 documentation, and it is intended that this application cover such additional inventive 
concepts. 
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Furthermore, certain terms that have been used in the foregoing and following 
descriptions of the present invention are defined as follows: 
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TERM 


DESCRIPTION 


Advertisement(s) 


This term is intended to broadly encompass any secondary content that is 
delivered or distributed to client devices in addition to the primary 
content, e.g., e-mail messages, which the software product instantiated by 
the client device is designed to receive, transmit, process, display, and/or 
utilize. For example, this term is intended to cover, without limitation, 
paid advertisements, community service messages, public service 
announcements, system information messages or announcements, cross- 
promo spots, artwork, and any other graphical, multimedia, audio, video, 
text, or other secondary digital content. Nevertheless, it will be 
recognized that the primary purpose of the presently contemplated 
commercial embodiment of the present invention is to distribute paid 
advertisements, and thus, in accordance with the preferred embodiment of 
the present invention, the advertisements will be exclusively, or at least 
primarily, paid advertisements. 


Client Device 


This term is intended to broadly encompass any device that has digital 
data processing and output, e.g., display, capabilities, including, but not 
limited to, desktop computers, laptop computers, hand-held computers, 
notebook computers, Personal Digital Assistants (PDAs), palm-top 
computing devices, intelligent devices, information appliances, video 
game consoles, information kiosks, wired and wireless Personal 
Communications Systems (PCS) devices, smart phones, intelligent 
cellular telephones with built-in web browsers, intelligent remote 
controllers for cable, satellite, and/or terrestrial broadcast television, and 
any other device that has the requisite capabilities. 
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Information 


This term is intended to broadly encompass any intelligible form of 
information which can be presented by a client device, i.e., an information 
client device, including, without limitation, text, documents, files, 
graphical objects, data objects, multimedia content, audio/sound files, 
video files, MPEG files, JPEG files, GIF files, PNG files, HTML 
documents, applications, formatted documents (e.g., word processor 
and/or spreadsheet documents or files), MP3 files, animations, 
photographs, and any other document, file, digital, or multimedia content 
that can be transmitted over a communications network such as the 
Internet. 


E-mail Messages 


This term is intended to broadly encompass the e-mail message and any 
attachments thereto, including, without limitation, text, documents, files, 
graphical objects, data objects, multimedia content, audio/sound files, 
video files, MPEG files, JPEG files, GIF files, PNG files, HTML 
documents, applications, formatted documents (e.g., word processor 
and/or spreadsheet documents or files), MP3 files, animations, 
photographs, and any other document, file, digital, or multimedia content 
that can be transmitted over a communications network such as the 
Internet. 


Software 
Provider 


This term is intended to broadly encompass the developer (or developers), 
sellers, distributors, etc., of the multi-mode software products(s) installed 
on the client device. 
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This term is intended to broadly encompass any device capable of storing 
and/or incorporating computer readable code for instantiating the client 
device referred to immediately above. Thus, the term encompasses all 
types of recording medium, e.g., a CD-ROM, a disk drive (hard or soft), 
magnetic tape, and recording devices, e.g., memory devices including 
DRAM, SRAM, EEPROM, FRAM, and Flash memory. It should be 
noted that the term is intended to include any type of device which could 
be deemed persistent storage. To the extent that an Application Specific 
Integrated Circuit (ASIC) can be considered to incorporate instructions 
for instantiating a client device, an ASIC is also considered to be within 
the scope of the term "memory." 



BRIEF DESCRIPTION OF THE DRAWINGS 

5 These and various other features and aspects of the present invention will be readily 

understood with reference to the following detailed description taken in conjunction with the 
accompanying drawings, in which like or similar numbers are used throughout, and in which: 
Fig. 1 is a high-level diagram of a computer system including a plurality of client 
devices connected to a plurality of independently-operated server devices via a network, 

10 which computer system is suitable for implementing various functions according to the 
present invention; 

Fig. 2 is a high-level diagram of a representative one of the client devices illustrated 
in Fig. 1; 

Figs. 3 A and 3B illustrate alternative and non-limiting placement of ads in the main 
15 navigation screen of an exemplary e-mail software application according to the present 
invention; 

Fig. 4A depicts state transitions when a version of the software is installed by one of a 
new user, an old user, and an EP4 user; 

Fig. 4B illustrates a dialog box associated with the state flow diagram illustrated in 
20 Fig. 4A; 
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Fig. 5 A illustrates an exemplary state flow diagram of a process by which the Ad user 
becomes a registered Ad user while Figs. 5B through 5G illustrate several dialog boxes 
associated with Fig. 5A; 

Fig. 6A illustrates an exemplary state flow diagram of a process by which a Free user 
can become a registered Free user while Fig. 6B illustrates an additional dialog box 
associated with Fig. 6A; 

Fig. 7A illustrates an exemplary state flow diagram of a process by which all users are 
reminded to update the software according to the present invention while Fig. 7B depicts an 
exemplary dialog box corresponding to an Update Nag; 

Fig. 8 illustrates an exemplary state flow diagram of a process by which a Box user 
can become a Paid user; 

Fig. 9 illustrates an exemplary state flow diagram of a process by which the Paid User 
becomes an Unpaid user; 

Fig. 10 illustrates an exemplary Nag Window display timeline for MacOS versions of 
the Eudora e-mail software according to an exemplary embodiment of the present invention; 

Fig. 1 1 illustrates a Nag Schedule employed by the software according to the present 
invention; 

Fig. 12 A is a simulated screen capture of a link history window employed in an 
exemplary software embodiment of the present invention while Fig. 12B is a dialog box 
reminding the user that the e-mail client according to the present invention is off-line; 

Fig. 13 A illustrates the assumptions used in determining the impact of ad transmission 
on e-mail program operations while Fig. 13B is a table listing the bandwidth requirements in 
terms of subscriber base versus the number of new ads to be downloaded each day; 

Fig. 14 is a state flow diagram of an exemplary ad fetch process according to the 
present invention; 

Figs. 15 A - 15H collectively illustrate an algorithm controlling ad scheduling in an 
exemplary embodiment according to the present invention; 

Figs. 16 A and 16B illustrate parameter variations in alternative modes of ad display 
possible in an exemplary embodiment according to the present invention; 

Figs. 17A through 17C illustrate additional dialog boxes which advantageously can be 
generated by the e-mail client software according to one aspect of the present invention; 
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Fig. 18 A illustrates an exemplary dialog box associated with auditing the operation of 
the Adware software according to the present invention while Figs. 18B through 18E list 
useful parameters for auditing the software's performance; 

Fig. 19 is a table summarizing the features of a plurality of web pages that 
5 advantageously can be employed in conjunction with an exemplary e-mail system according 
to one aspect of the present invention; 

Fig. 20 is a class diagram illustrating the mapping of XML code to objects and the 
task flow when another exemplary embodiment according to the present invention is 
operating in accordance with doPost methodology; 
; yl0 Figs. 21 A and 21B collectively constitute a pseudo code listing which can be 

^ employed by the server 302 in Fig. 1 in generating a PlayList in accordance with the present 
invention; 

Ly Fig. 22 is another class diagram illustrating handling of requests and writes between a 

server and at least one of the client computers depicted in Fig. 1; and 
: ^ 15 Fig. 23 illustrates database accesses in accordance with another aspect of the present 

q invention. 

DETAILED DESCRIPTION OF THE PREFERRED EMBODIMENTS 

20 

Illustrative embodiments and exemplary applications will now be described with 
reference to the accompanying drawings to disclose the advantageous teachings of the present 
invention. 



25 While the present invention is described herein with reference to illustrative 

embodiments for particular applications, it should be understood that the invention is not 
limited thereto. Those having ordinary skill in the art and access to the teachings provided 
herein will recognize additional modifications, applications, and embodiments within the 
scope thereof and additional fields in which the present invention would be of significant 

30 utility. 
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Referring now to specific drawings, Fig. 1 illustrates an exemplary system 
configuration 10 which is suitable for carrying out the functions according to representative 
embodiments of the present invention. Although the representative embodiment will be 
generally described with respect to an electronic mail (e-mail) system where a number of 

5 users can create, send, receive and read e-mail messages, the present invention is not so 
limited. For example, the present invention is equally applicable to a personal digital 
assistant (PDA) incorporating specialized software for receiving stock quotations via a 
wireless network. Thus, the principles of the present invention should not be regarded as 
limited solely to e-mail systems; the principles of the present invention apply to on-line 

10 services where a provider, e.g., a software provider, desires to make its software available to 
users using a variety of payment options for a core set of software functions. 

As shown in Fig. 1, the system 10 includes a plurality of client computers 100a, 100b, 
lOOn, where n denotes any positive integer. Preferably, each of the client computers 

15 generally denoted 100 can be either a workstation or a personal computer executing a client 
program according to the present invention. In an exemplary case, the client computers 100a, 
100b, lOOn advantageously can be connected to a plurality of servers 301 - 304, which 
servers will be described in greater detail below, via a network 200, e.g., the Internet. 
Alternatively, the network 200 can be one of a local area network (LAN), a wide area 

20 network (WAN), an Intranet, or a wireless network, or some combination thereof. It will be 
appreciated that Fig. 1 illustrates a non-limiting exemplary system; and number of clients can 
be connected to any number of servers. 

Fig. 2 illustrates in further detail the hardware configuration of an exemplary one of 
25 the client computers 100a, 100b, lOOn illustrated in Fig. 1. In the representative 
embodiment, the client computer 100a includes a central processing unit 209 for executing 
computer programs (including the client program according to one exemplary embodiment of 
the present invention) and managing and controlling the operation of the client computer 
100a. A storage device 205, such as a floppy disk drive, is coupled to the central processing 
30 unit 209 for, e.g., reading and writing data and computer programs to and from removable 
storage media such as floppy disks. Storage device 206, coupled to the central processing unit 
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209, also provides a mechanism for storing computer programs and data. Storage device 206 
is preferably a hard disk having a high storage capacity. A dynamic memory device 207 such 
as a RAM, is also coupled to the central processing unit 209. It will be noted that storage 
devices 205 and 206, as well as dynamic memory device 207, are non-limiting examples of a 
5 memory, which term was defined previously. The client computer 100a includes typical 
input/output devices, such as, for example, a keyboard 203, a mouse 204, a monitor 208, and 
a communications device 201. It will be appreciated that the communications device 
advantageously can be a modem, an ethernet interface card, etc. 

; Sl0 Referring again to Fig. 1, each of the client computers 100a, 100b, lOOn can 

;;• : selectively communicate with any of the servers, e.g., servers 301 - 304, via the network 200, 
fi In the computer system 10 depicted in Fig. 1, each of the servers performs a specialized 
tTi function. In an exemplary case, server 301 performs a registration function, i.e., accepts 
; y registration information from each client computer (as discussed in greater detail below), 
M= is server 302 provides PlayLists to the client computers 100a, 100b, lOOn, server 303 
;;3 provides the advertisements designated in the PlayLists, and server 304 acts as a conventional 
% e-mail system server system, i.e., provides both the incoming e-mail server and the outgoing e- 
□ mail server. It should be mentioned that only servers 301 and 302 need actually be under the 
direct control of the software provider, e.g., QUALCOMM INCORPORATED in the 
20 preferred embodiment, although server 303 advantageously may be under the control of the 
software provider as well. It should also be mentioned that the reference to software should 
not be construed as limited to disk based software; the term "software" should be broadly 
interpreted as instructions carried out by a processor, whether these instructions are read from 
a dynamic memory or stored as firmware in an read only memory (ROM) or other variants of 
25 such a device. 

According to one aspect of the present invention, the "software" advantageously can 
be provided as a single binary (per client device) file containing the software, e.g., the Eudora 
software, which can be employed by all users. This binary file will operate in one of three 
30 major modes of operation: Payware; Freeware; and Adware. In the Payware mode of 
operation, the user must pay the software provider to use the software. Freeware is free for 
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all to use, but has fewer features than either Payware or Adware. Preferably, Payware users 
will prove their payment by a registration code that the software provider will provide to 
them at time of payment. This code will be self-validating, and contain enough data to 
identify what version(s) the user is entitled to operate. It should be noted that users of the 

5 Payware version of Eudora will be entitled to all versions of Eudora that are produced during 
the calendar year following their payment. The software preferably polls a predetermined 
site, e.g., a site maintained by QUALCOMM INCORPORATED, on a periodic basis in order 
to determine if an update for the software is available; if an update is available, the software 
advantageously can present the user with a small web page of options for obtaining the 

10 software update, as discussed in greater detail below. 

It will be noted that Adware has all the features of Payware, but does not require 
payment from the user. What Adware does require is that the user display and view ads, 
which the user will download from the software provider's site and/or one or more sites 
15 designated by the software provider. It will also be noted that the initial state of the software 
is Adware. 



In an exemplary preferred embodiment, each client computer downloads ads from the 
ad server 303 unobtrusively and without drawing significant bandwidth, as discussed in 
20 greater detail below. Moreover, the ads advantageously can be displayed in a manner that 
doesn't significantly detract from the use of the software, e.g., Eudora. Figs. 3A and 3B 
illustrate advertisements integrated into the main screen of the exemplary Eudora e-mail 
software. 



25 Some of the terminology employed in describing the functions and novel features of 

exemplary embodiments of the present invention was presented above. Additional 
terminology which facilitates a full understanding of the present invention in terms of the 
Eudora software is presented immediately below. 



Applications 



QUALCOMM INCORPORATED has several versions of the Eudora 
software, including: 
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EP4 


Eudora Pro 4.x, either Windows or Macintosh. 




Eudora 


The new three-modal version of Eudora, running in any of 
its modes. 




Payware 


Eudora running in full-feature mode, after the user has paid. 




Freeware 


Eudora running in reduced-feature mode. 




Adware 


Eudora running in full-feature mode with ads. 




Paid App 


Any version of Payware to which the user's registration 
entitles him/her. 




Unpaid App 


Any version of Payware newer than that to which the user is 
registered and entitled to. 


Old Eudora 


Eudora versions prior to Eudora Pro 4.x, 


User States 


A user state is the most basic concept to understanding how the various 
modes of the application are interrelated. The user state determines how the 
program treats the user. The states are defined as follows: 




EP4 User 


A user of EP4 who has not registered via the old (non- 
Adware) registration process. 




Registered 
EP4 User 


A registered user of EP4. 




New User 


A user using Eudora for the first time, but who has not 
obtained a boxed copy, e.g., bundled with a newly purchased 
computer system, etc. 




Payware 
User 


A user who has paid for Eudora, entered his/her registration 
code, and is using a version of Eudora to which he/she is 
entitled. 
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Box User 


This is a user who has been given their RegCode by an 
installer, either from the box product or from an EP4 
updater, and whose registration information is therefore 
unknown. 




Free User 


A user who has chosen to use Freeware but who has not 
entered a Freeware registration code. 




Adware 
User 


A user who is using the Adware version that displays ads. 




Registered 

Freeware 

User 


A Freeware ("Free") user who has entered a Freeware 
registration code. 




Registered 

Adware 

User 


An Adware user who has entered an Ad registration code. 




Deadbeat 
User 


A former Adware user who has been shut off due to 
Eudora's failure to receive ads (or less than a prescribed 
minimum number of ads). 


Windows and 
Dialogs 


Several windows and dialogs are used in the process. A fuller description of 
these will be given later, but the major ones are briefly described 
immediately below: 




Intro Dialog 


A dialog presented to new users explaining the software 
options to new users. 




Registration 
Nag 


A window presented to the user every so often to suggest 
that the user register his/her software. 




Full- 
Feature Nag 


A window presented to Freeware users requesting them to 
try Eudora Pro again. 
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Free 

Downgrade 


A dialog that tells the user the features that will no longer be 
available to him/her if they switch to Freeware, but allows 
them to do so if they really wish. 




Code Entry 
Dialog 


A dialog allowing the user to enter their registration code. 




Ad Window 


A window or portion of a screen displaying an ad. See 
Figs.3A and 3B. 




Link 

History 

Window 


A window that will display links the user has clicked on, i.e., 
ads the user has seen. 


Web Pages 


The software provider advantageously can elect to restrict interactions 
between the user and the software provider to the Internet to the maximum 
extent possible. This will allow the software provider the most flexibility in 
how the software provider deals with actual users. One potential list of the 
major pages is provided immediately below, although these "pages" 
advantageously may be groups of pages, or pages customized to match the 
demographics of a given user, e.g., a customized and/or branded version of 
Eudora provided by a major retailer, e.g., a private label version of Eudora 
provided to its users by an ISP. 




Freeware 
Reg Page 


A page that allows the user to register Freeware. 




Payware 
Reg Page 


A page that accepts payment for Eudora Pro and returns a 
registration code to the user. 




Adware Reg 
Page 


A page that allows users of Adware to submit their 
registration information to the software provider. 




Lost Code 
Page 


A page that helps users who have lost their registration 
codes. (May require human intervention) 
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Update 
Page 


A page generated for a user that lists possible upgrades and 
the latest version for which he/she is registered. 




Archived 
Versions 
Page 


A page from which users can download all versions of 
Eudora. 




Profile Page 


A web page where users can enter their profile information. 


Nag Schedules 


A "Nag Schedule" is a bracketed set of numbers. The numbers signify # of 
days since the start of a trial period. Users will be nagged on the days 
indicated. The last number signifies what happens when the other numbers 
run out; the user will either not be nagged (0), or be nagged every so many 
days. For example, a schedule of [0,5,2] means the user will be nagged on 
the first day, the sixth day, and every other day thereafter. 



As mentioned above, the "software" advantageously can be provided as a single 
binary file containing the software, e.g., the Eudora software, which can be installed (if 
required) and employed by all users. This binary file will operate in one of three major modes 

5 of operation: Pay ware; Freeware; and Ad ware. The installation and operation of various 
functions of the software program according to the present invention will now be described in 
greater detail while referring to several state flow diagrams, which state diagrams illustrate 
the major user states and the transitions among them. In the flow state diagrams, the 
following conventions will be observed: 

10 • Raised grey squares are conceptual names for buttons in dialogs. 

• A few paths are labeled with menu items. These items can be used to bring up 
the window in question directly, without waiting for nags. 

• In principle, any dialog or nag can be cancelled, leaving the user back in the 
initial state. 

15 • Web pages cannot change user state or generate more dialogs; hence, all web 

pages lead back to the user's initial state. 



-23- 



[PA000373] 

With the conventions noted above, the installation of the Eudora e-mail software will 
now be described while referring to Fig. 4, which depicts state transitions when a version of 
the software is installed by one of a new user, an old user, and an EP4 user. It will be noted 
that the software provider doesn't give the user the options to pay for the full feature set or to 
5 accept the software with a reduced feature set in the intro dialog. While the software provider 
will explain those options, e.g., via a dialog box similar to that illustrated in Fig. 4B, as well 
as the fact that the user can obtain these alternative versions of the software feature set by 
going through the Help menu, the software defaults to the Adware version. 

10 The path taken by EP4 users and box purchasers illustrated in Fig. 4A merits some 

elaboration. The Code Generator referred to in Fig. 4A advantageously is instantiated by the 
installer module of the binary file, not in the Eudora e-mail program itself. If the user is using 
the software's 4.x -> 4.3 update function, the software searches for a copy of EP4 and, on 
finding a copy of the software, the Code Generator permits the user to generate a RegCode 

15 file. If the user is running the installer out of the box, the installer permits RegCode 
generation without looking for a copy of EP4 first. It should be mentioned that the RegCode 
file so generated is special in that it contains a line saying "Eudora-Needs-Registration: 
YES." The Eudora e-mail software will notice this line of text, put the user into the 
unregistered state, and then nag the user to register the software. Once the user registers, the 

20 same registration code will be re-transmitted to the user, and the Eudora e-mail software will 
silently accept it (since it will be the same as the current code), and turn off the need to 
register flag in the e-mail software. 

Fig. 5A illustrates a state flow diagram of the process by which the Adware user 
25 becomes a registered Adware user. It will be appreciated that, in the illustrated exemplary 
case, the registration process necessitates interaction between client computer 100a and a 
registration server 301, which are connected to one another via network 200. In Fig. 5 A, the 
Adware user indicated in Fig. 4A registers with the software provider through several 
alternative mechanisms. For example, the Ad user may wish to register, and simply activates 
30 the "HELP" pulldown menu, which is available from the tool bar illustrated at the top of Fig. 
3A, and selects the Payment & Registration option, as depicted in Fig. 5B. Alternatively, the 
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Adware user may receive a Nag box, i.e., a Nag dialog box, generated by the software at a 
predetermined time, as discussed more fully below. Finally, the Ad user may receive a 
registration via e-mail, i.e., a registration code generated by server 301 and transmitted to the 
client computer 100a by way of e-mail server 304. 

5 

As shown in Fig. 5B, the Payment & Registration Window provides several selection 
buttons, which allow the Ad user to register the Adware, pay for the software, list all versions 
available to the user, customize or modify the ad stream by providing demographic 
information, enter a received registration code, and downgrade to the reduced feature set 
10 offered to Freeware users. See Figs. 5C - 5G. It should be mentioned that the user can enter 
a registration code to become one of a registered Adware user, a registered Freeware user, 
and a registered Payware user. See Fig. 5F. It will be appreciated that the software operates 
in accordance with the same state flow diagram for Registered Adware Users, except that the 
Registered Adware User is not subjected to the Registration Nag. 

15 

The software provider advantageously can use a registration scheme with a self- 
validating registration code, so that databases do not need to be used to validate registrations. 
The algorithm for verification is intended to satisfy several conflicting constraints, i.e., it 
needs to be secure, yet easy to implement and not unduly burdensome for the user. The 
20 Eudora e-mail software checks its registration code at startup for validity. If the registration 
code is invalid, the user should be considered unregistered. If the user is a paid mode user, 
this will involve a switch to Sponsored mode, about which the user should be warned using a 
dialog box (not shown). This alert will be followed by an opportunity to reenter the code. The 
necessary inputs to generate the registration code are as follows: 

25 



-25- 



[PA000373] 



RegName 


The name the user wishes to register under. The software provider will imply but 
not require that this be the user's real name. The only thing this name will be used 
for is registration. 

Supplied by the user. When the software provider actually collects this name from 
the user, the software provider will ask for it in terms of first and last names, called 
RegFirstName and RegLastName, respectively. RegName is built by concatenating 
RegFirstName, a single space, and RegLastName. Each of the first and last names 
is limited to 20 significant characters; beyond that, characters will be ignored. 


RegMonth 


rpi j - _ n r ji ^.^ • f-s^y avr»i*(3ccAfl qc tH pi n i imhpr of months since Tan 1. 1 777, 
The date 01 the registration, expressed as ine iiumuci ui uiunuia jan 

e.g., 8 bits (20 years). All l's is reserved are for "never expires" situations. 


Product 


A numeric code indicating what product the registration is for. The user will choose 
the product; the software provider will translate that choice into an 8-bit code. 



It will be appreciated that a plurality of RegCode algorithms advantageously can be 
employed in generating a self-validating registration code. In brief, the software provider 
takes the inputs listed above, checksums them, mixes the inputs (including the RegName) and 
the checksum together in according to any one of a variety of algorithms, and encodes the 
result as a 16-bit number string. It will also be appreciated that the encoding and bit-mixing 
can be reversed and then, together with the RegName, the checksum can be used to verify the 
validity of the registration code. 

It should be noted that the software provider will store registration codes separately 
for Freeware (Eudora Light), Adware (Sponsored) and Payware (Eudora Pro) software 
modes. Acceptance of a registrations code for one mode of operation does not imply that the 
registration codes for the other modes should be destroyed. 

Once the registration code has been generated, the user must somehow enter the valid 
RegCode into the Eudora e-mail client. This can be accomplished in one of three ways: 

• Manually. Users can type or paste values into the Enter Code dialog box. See 
Fig. 5F. 
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• Windows Registry. At Eudora startup, the software will look for the RegCode in 
the Windows registry (e.g., Software\Qualcomm\Eudora\Check, FName, LName, 
RCode). The values should be copied into the preferences register or associated 
lookup table of the e-mail client, if these preferences are found and valid. 
5 • RegCode File. At Eudora startup, the software will look for a file in the 

application software folder named "RegCode.dat," in an exemplary case. The 
values should be copied into the preferences register or associated lookup table of 
the e-mail client, if these preferences are found and valid. 

10 It should also be mentioned that the software provider will allow a special-case 

MIME part to be mailed to the Eudora e-mail client. The user receiving this part will 
automatically be asked to verify and enter the information. He/she can also execute the 
attachment again later. However, he/she cannot forward the attachment to anyone else using 
the Eudora e-mail client, because a special Content-Type attribute ("regCode") is required to 

15 activate the part, and the Eudora e-mail client can't send those. 

The format of the MIME part (and the RegCode file) is that of a text file containing 
RFC822-header-style fields. It has a registered MIME type of application/vnd.eudora.data. 
The fields included in the part are: 

20 



Eudora-File-Type 


This is always the first field, and describes what sort of information the 
rest of the file contains. Its value will be either "regFile" or "Profile." 


Eudora-First-Name 


The first (given) name of the registrant, in US-ASCII. 


Eudora-Last-Name 


The last (family) name of the registrant, in US-ASCII. 


Eudor a-Reg- Code 


The registration code as produced by the registration system 


Profile 


Profile information. This takes the form of a relatively short, e.g., 127 
bytes, ASCII string. A profile is generated for each user during the 
registration process. 
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Eudora-Needs- 
Registration: 


If this field contains "YES", then the user should be nagged to register 
their copy of Eudora. This is used by installers that generate RegCodes 
that the software provider otherwise would not have in its database. 


Mailed-To 


This is the address the information was mailed to. If this field is present 
and does not match any of the user's personalities or "me" nickname, 
the information should not be acted on. 



It should be noted that the Eudora-File-Type field must be present. The other fields 
listed above may or may not be present. 

It will be appreciated from the discussion above that RegCodes mailed to the user 
should be validated prior to use. In order to be used, a RegCode should meet the following 
tests: 

• Validity - An invalid RegCode should be ignored. 

• Directness - The mailed-to field of the RegCode should contain an address for one of 
the user's personalities or be in the user's "me" nickname. 

• Applicability - A new RegCode should not automatically override an existing valid 
RegCode. The only exceptions to this policy are that a Payware mode RegCode 
should override a Freeware or Adware RegCode, and a Payware mode RegCode that 
is the same as the user's existing Payware mode RegCode can be used to disable the 
"Eudora-Needs-Registration" Nag. 

Once the RegCode has been determined to meet the above tests, the user should be 
asked to accept the code. An exemplary acceptance dialog box is illustrated in Fig. 5F. 

As mentioned above, the registration code is self-validating, since one part is a 
function of the other. However, there is another sense of "validation" to be considered, i.e., 
whether or not the registration code is "valid" for use with a particular version of Eudora. 
This is accomplished by comparing the ExpMonth in the registration code with a BuildMonth 
field the software provider will put into the application (in a place that cannot be overwritten 
by plug-ins, settings, etc.). If the ExpMonth and the BuildMonth correspond, the registration 
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is deemed valid by the e-mail client. 

Fig. 6A illustrates a state flow diagram of the process by which a Freeware user can 
become a Registered Free User. It will be appreciated that the state flow diagrams of Figs. 

5 5 A and 6A are similar in many respects. However, the state flow diagram of Fig. 6 A allows 
for an additional Nag dialog box, i.e., the so-called Feature Nag dialog box pictured in Fig. 
6B, to remind both the Free User and the Registered Free User of the enhanced features 
available to Adware and Pay ware users. With respect to Freeware Users and Registered 
Freeware Users, it will be appreciated that the Registered Freeware Users will not receive the 

10 Registration Nag dialog box. It will be appreciated that the state flow diagram illustrated in 
Fig. 6A is very similar to that applicable to the Adware Users (Fig. 5 A), with the exception 
that Freeware Users are given the option to try the full features rather than enter their 
demographic information. 

15 It should also be mentioned at this point that all users will receive an Update Nag 

dialog box (not shown) at a predetermined interval. Eudora checks the Update Page once per 
week during an e-mail session. If the Update page has changed, the user is nagged to update 
the Eudora e-mail software. Even if the page hasn't changed, the user is nagged on a 30-day 
schedule to check for updates, to ensure that he/she has the latest software version. See the 

20 state flow diagram of Fig. 7 A. The Update Nag presents the user with versions to which 
he/she is entitled to upgrade (if any). See Fig. 7B. The Nag itself is an HTML document with 
links to versions of the Eudora e-mail software for the user to download. 

Fig. 8 illustrates an exemplary state flow diagram of the process by which a Box user 
25 can become a Paid user, i.e., a Payware user. It will be appreciated that the only Nag the 
software provider presents specifically to the Box users is the Registration Nag. Once a Box 
user registers, the Box user is converted into a normal Paid user. It should be mentioned 
however that the payment date for the Box user is set to a specific value by the software 
provider, so that the software provider can control what versions of the software the Box user 
30 will receive, e.g., the period of time for which the user will receive updates from the software 
provider for free going forward. 
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Having introduced the concept of nagging, this would be a convenient point to discuss 
various features of nagging implemented in the software according to the present invention. 
Two major issue are (1) how the software provider nags the user, and (2) when the software 
5 provider nags the user. 

Ideally, Nag Windows are modeless windows. The user can close them using close 
boxes, or dismiss them by taking one of their action items, or simply leave them open and let 
them drift wherever they will in the window list. Due to implementation constraints, 
10 Windows Nag Windows will be slightly different in behavior than MacOS Nag Windows, 
which are discussed below. The Nag Windows are floating windows; the software provider 
expects that the user will probably dismiss the Nag Window in fairly short order. It will be 
appreciated that the Nag Windows will not, however, stop background tasks from executing. 

15 It should be mentioned that there is at most one Nag Window of each variety open at 

a time; old windows of the same variety advantageously will be recycled. That is, if a given 
Nag Window is still open the next time the user is due to be nagged, that window will be 
reused and brought back to the top of the window stack. It should also be mentioned that all 
Nags applicable to the user should be available to the user by selection from the Help menu, 

20 so that the user who dismisses one of the Nag Windows inadvertently can deliberately nag 
him/her-self if he/she wishes, although such manual Nag invocations do not reset the Nag's 
timer. 

Preferably, Nag Windows will be opened on top of all other windows, and no 
25 automatically opened windows, including, for example "Tip of the Day" and other dialog 
boxes and excluding other Nag Windows, will ever be placed above them until the user has 
manually brought another, non-Nag Window above them. Due to the implementation 
constraints in the Windows version of the Eudora e-mail software, the only windows that can 
obscure Nags would be other floating windows. It will be appreciated that this is chiefly due 
30 to the requirement that Multiple Document Interface (MDI) child windows be maximizable. 
It should be mentioned that is a standard Windows interface used by many popular Windows 
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applications and utilities, such as the Windows Program Manager, and the Windows File 
Manager; the MDI interface is also part of the Common User Access (CUA) standard set by 
IBM. Each MDI-compliant application enables you to open child windows for file-specific 
tasks such as editing text, managing a database, or working with a spreadsheet, to name but a 
5 few of the possible tasks. 

Fig. 10 illustrates a flow chart for Nag Window display in MacOS versions of the 
Eudora e-mail software according to an exemplary embodiment of the present invention. In 
Fig. 10, the software presents just the In mailbox, as denoted by the symbol (1), i.e., time (1). 

10 The Eudora e-mail software then determines that it needs to nag the user, and places the Nag 
atop the mailbox, as denoted by the symbol (2). Some mail arrives in the "Fresh Meat" 
mailbox. Ordinarily, this would open on top. However, since there is a "new" Nag being 
displayed by the software, i.e., one the user has not manually sent behind anything, the "Fresh 
Meat" instead opens below the Nag, as denoted by symbol (3). The user manually brings 

15 Fresh Meat to the front, as denoted by symbol (4). After that, when mail arrives in More 
Meat, the Nag is no longer new, and More Meat can be opened on top in the normal manner, 
as denoted by the symbol (5). 

The placement of Nag Windows in any of the Windows environments is, in general, 
20 considerably simpler. Nag Windows simply float outside the MDI box, above other floating 
windows, until the user closes them. The exception to this rule is the Update Nag, which acts 
like a MacOS Nag Window, if the user assumes that the entire Macintosh diagram takes place 
inside an MDI box. Note particularly that this indicates that the Update Nag may be 
maximized in the Windows environment. 

25 

Although the basic concept of Nag Schedules was introduced above, a more detailed 
discussion of Nag Schedules at this point would facilitate the understanding of certain aspects 
and features of the software according to an exemplary preferred embodiment of the present 
invention. In the Eudora e-mail software, each schedule is a set of numbers representing 
30 (save for the last) the number of days since a given date (the Nag base). The software 
provider further must keep track of the last time the user was nagged (the last lag). Note that 
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both the Nag base and last Nag should be tracked separately for each type of Nag; the 
software provider must not mix values for Registration Nags and Update Nags, for example. 
The last number of the Nag Schedule is a repeat interval. Once the other Nags are all 
exhausted, the user is nagged each time this last number of days passes. 

5 

The best way to understand a Nag Schedule is to view the schedule as a timeline, as 
illustrated in Fig. 1 1. This particular timeline is for a Nag Schedule of [0,4,9,12,3]. Note that 
the Nags which will occur at the 15 and 18 day points are there because of the final number, 
the repeat interval (of 3 days). Thus, in Fig. 11, the user is due to be nagged if there is a Nag 
10 day greater than the last Nag and less than or equal to the current day. If more than one Nag 
day has passed, the user is still nagged only once. 

It should be mentioned that once the Nag Window has been opened, the last Nag is 
reset to the current day. It should also be mentioned that a final Nag interval of 0 indicates 

15 that the Nag is not done any more after the defined period has expired. It will be appreciated 
that the Eudora e-mail software advantageously includes a software subroutine which 
determines whether any Nags are due at application startup and at the completion of each 
mail check. With respect to the latter case, the software checks the modification date on the 
Update Page once per week during a mail check. If the Update Page has been modified 

20 during the past week, the software provider will download update information during the mail 
check, and nag the user to update his/her software, e.g., the Eudora e-mail software. See Fig. 
7B. Finally, it will be noted that when a user's state changes so that an open Nag is no longer 
relevant, that Nag is closed and no longer displayed. 

25 The preceding discussion also touched briefly on various issues with respect to ads; 

these issues will be developed more fully immediately below. More specifically, the major 
client issues involving ads are how the software displays the ads, when the software displays 
the ads, how the software obtains the ads, how the software provider obtains and transmits 
demographic information, and how the software provider verifies that ads are actually being 

30 displayed. 
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Referring again to Fig. 3A, the main window of the Eudora e-mail software shows a 
squarish ad and three ad buttons in opposite corners of the main window. It should be 
mentioned that this particular squarish ad is 144 pixels high by 128 pixels wide; the software 
will accommodate ads as large as 144 pixels by 144 pixels. It will be appreciated that the 
5 area of the window usable by the mailboxes has been reduced approximately 38%; however, 
it will also be appreciated that the content area has been left untouched. Fig. 3B illustrates an 
alternative main window where a small graphic or placard is employed, e.g., in the lower 
right corner, to indicate that the main window is sponsored. 

10 It will be appreciated that the actual information that the software provider can accept 

from advertisers will be relatively simple. For standard ads, such as that depicted in the lower 
left-hand corner of Fig. 3A, the ad will consist of an image file, e.g., a GIF file, a PNG file, a 
JPEG file, etc., of not more than 15K, and not more thanl44 pixels tall by 144 pixels wide. 
Preferably, this image file will employ the Web Safe Color Palette. This palette, which is 

15 sometimes to as the Browser-Safe Palette, contains only 216 colors out of a possible 256 
colors definable by 8-bits. The remaining 40 colors vary on Macs and PCs. By eliminating 
the 40 variable colors, this palette is optimized for cross-platform use. Moreover, the image 
file advantageously will be associated with a single uniform resource name (URN) to which 
users who click on the ad will be directed. Each advertiser will also specify the desired 

20 scheduling information for the ad, as discussed in greater detail below. In order to facilitate 
the transmission of the ad to the software provider, e.g., QUALCOMM INCORPORATED, 
the advertiser may wrap the ad in HTML. The software provider advantageously can also 
employ HTML-wrapped ads, since this will allow the software provider to include ad 
parameters as META tags in the HTML page, specify the link address, etc. 

25 

Moreover, the Toolbar icons will be requested in GIF format as well, but will actually 
be delivered to the client in a composite format and transformed into standard icons. In 
addition, placards for sponsors of the Freeware version illustrated in Fig. 3B should be no 
more than 31 pixels tall, and on the order of 88 pixels wide, though the precise width can be 
30 varied at runtime. 
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It should be mentioned here that when the user clicks on an ad, the software provider 
will normally take the user to the software provider's click-through counter and then redirect 
the user's browser to the link listed with the ad. The click-through counter advantageously 
can be one of the software provider's servers, e.g., one of servers 302 and 303. It will be 
5 appreciated that this will require that the software provider will compose a URN which 
includes a server name, some tracking information, and the ultimate destination URN, and 
then the server will redirect the user's browser to the destination URN. 

One complication occurs if the user is offline at the time that the click-through is 
10 attempted. When the user is offline, several possible actions by the software are possible. 
For example, the software could initiate an online session. Alternatively, the software could 
simply flag the link using the link history facility. See Fig. 12, which depicts a window/menu 
that the software maintains, similar to the history lists maintained by most browsers. When 
the ad is clicked while the software is offline, the software advantageously adds the link to 
15 the link history window, and flags this link so that the user knows he/she had wanted, but was 
unable, to visit that site during a previous e-mail session. 

Moreover, the software advantageously may be constructed to permit the user's 
browser respond to the click-through. It will be appreciated that some browsers have 
20 sophisticated features of their own for dealing with offline conditions, and the software 
provider shouldn't discount the idea that the user might wish to rely on them. Alternatively, 
the software may permit transmission of the link to the browser for subsequent handling by 
the browser when it is online, i.e., the software can allow the user to tell the software provider 
to send the link to the user's browser the next time he/she is online. 

25 

In summary, the software provider will, in an exemplary and non-limiting case, 
mandate that the following standard for all advertisements submitted by advertisers: 

• No larger than 144x144 pixels. Ads smaller than this will be centered in a 
144x144 window and surrounded by the standard frame color. 
30 • GIF or JPEG, The software provider advantageously can convert the GIF file 

to a PhotoShop (PNG) file, but this is transparent. It should be noted that the software 
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provider will not presently accept PNG ads directly, because of the gamma bugs in 
PhotoShop. 

• No larger than 15K. This will reduce the bandwidth required to transmit the 
ad as well as the goodwill cost of user bandwidth. 

5 • No animation. This is a cornerstone of the "unobtrusive" message to users 

aspect of exemplary embodiments of the present invention, 

• A single URN of not more than 900 characters. There are suspected limits 
of IK on URN size. Limiting the customer's URN to 900 characters will allow the software 
provider to annotate the URN and still stay within the IK limit. 

10 • A user-friendly title string of not more than 31 characters. This string will 

be displayed in the link history window, and should be something users will relate to. 

• Use Web Safe Color Palette. This 216-color palette optimized for users with 
256-color systems, as mentioned above. 

15 It should be mentioned that Toolbar buttons, i.e., the buttons in the upper right-hand 

corner of Fig. 3A have the same requirement as standard ads, except for the following: 

• Both 16x16 and 32x32 sizes required. These are the sizes the client supports, 
the software provider needs them both. 

• GIF only. The software will not render JPEG images in the toolbar. 

20 

With respect to the co-brand spot ad illustrated in the lower right-hand corner of Fig. 
3B, the spot has the same requirement as standard ads, except for the following: 

• No larger than 95 pixels wide by 31 pixels high. 

• GIF only. 

25 

One troublesome issue regarding the ad placement illustrated in Fig. 3A is the relative 
ease with which a user might be able to hide the ads from view by placing a small window 
directly over the ad. Advantageously, the software performs a check to determine that the ad 
is both onscreen and uncovered. If the screen state does not satisfy both of these criteria, the 
30 software will either nag the user to uncover the ad or automatically re-order the windows so 
that the ad is uncovered. If the user persists in covering the ad for a predetermined period of 
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time, the software will automatically devolve to freeware mode. 



Since one of the major reasons for providing an Adware version of software such as 
the Eudora e-mail program is to provide a mechanism by which advertisers can subsidize the 
5 cost of the software, the software provider is clearly motivated to ensure that all Eudora users 
are actually looking at the ads. Stated another way, displaying an ad on the screen of the 
client computer 100a, for example, while the user is in another room does not justify the 
expense of the ad for the advertiser. For that reason, the software includes functions which 
permit measurement of the actual time that the user is in front of the computer while the ad is 
S ;B 10 present. 

Absent some sort of positive ocular fastening device, the best thing the software can 
Uj do to measure user attention is to monitor for user input to the client computer 100a, thus 
verifying the user's presence in front of the display device 208. Given that the primary user 
l X 15 input devices to the client computer 100a are the mouse 204 and the keyboard 203, the e-mail 
Q client will monitor for both mouse and keyboard operation by the user when the Adware 
; ij version of the Eudora e-mail client is frontmost, and periodically report this activity back to, 
u ' for example, the software provider. In other words, the user will be considered "present and 
accounted for" if the mouse moves significantly, if a mouse button states change, or if keys 
20 are pressed or released. Moreover, the software will consider a period before and after such 
an event as "face time" for the ad. In an exemplary case of the software according to the 
present invention, the software measures the period and refers to the total length of this 
period as kFacelnterval. There is no need to be overly precise about this values, e.g., a 
kFacelnterval of sixty (60 )seconds, which begins with a user event, is employed in the 
25 exemplary, non-limiting case being discussed. 

Having discussed the format of the ads being displayed by the software, a detailed 
discussion of the methodology by which the ads are actually obtained for display will now be 
presented. The general methodology for obtaining ads for display is to connect to a 
30 QUALCOMM INCORPORATED site during a mail check, or some other time when the 
software senses a live network connection, and download ads into a local cache. It will be 
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appreciated that the act of downloading the ad can be the trigger for billing the advertiser, in 
order to avoid the necessity of collecting billing information from individual clients. In 
contrast, proprietary systems such as that provided by JUNO, upload ad display data to the 
designated e-mail server whenever the user accesses his/her e-mail account for any reason. 

5 

In order to make reasonable decisions about how to download ads, the software 
provider needs to have some idea of what impact the ad downloads will have on users. In 
order to assess that impact, the software provider must make assumptions (or gather 
information) about what a typical Eudora user's habits are, and what the ads will be like in 
= ; 0 10 terms of transmission characteristics. Part of the Adware process is to add instrumentation in 
'C$ the software client so that the software provider can begin to answer these questions 
intelligently, rather than by guesswork. However, one must start with some basic 
UJ assumptions. For example, Fig. 13A is a table listing the assumptions used in detemiining 
the impact of ad transmission on e-mail program operations; Fig. 13B is a table listing the 
vf 5 15 bandwidth requirements in terms of the subscriber base versus of the number of new ads to be 
O downloaded each day to the subscribers. The implications of these calculations are as 
follows. Given that the goal is for an average turnover of an ad is, for example, three days, 
Q~ the top line in the table illustrated in Fig. 13B would be the one used by the software 
provider. The worst-case, i.e., maximum bandwidth, scenario would be to turn over, for 
20 example, 25 ads a day. These values are highlighted in the table of Fig. 13B. 

In order to determine what ads are to be shown for a particular user class, as well as in 
order to transmit particular ad parameters, the software provider advantageously employs a 
PlayList. The PlayList is in its essence a list of URNs from which to fetch the actual ads as 

25 well as a set of attribute-value pairs, on a per-ad basis. The exact format of the PlayList is 
discussed in greater detail shortly. PlayLists will specify the complete set of ads the client 
should have, along with parameters for displaying those ads, as discussed immediately below. 
It should be noted that ads may appear in a PlayList but not be scheduled for display for a 
long time (or even at all). The presence of such ads in the PlayList will cause the client to 

30 retrieve the ads for storage on the client for future display. The general requirements for the 
PlayList are as follows: 
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1) The request for a PlayList will contain information to help the PlayList server 
determine what ads a copy of Eudora is required to fetch. 

2) The PlayList can also contain parameters for Eudora as a whole, including the 
ability to modify how often New PlayLists are checked for. 

5 3) PlayLists are allowed to specify whether or not they should replace all older 

PlayLists or merely be merged with them. It should be mentioned that the merge function will 
allow a more web-like advertising model, e.g., a model employing a rotating ad pool, should 
the software provider choose to employ such a model. 

10 The basic ad fetch process will now be described while referring to Fig. 14, which is a 

state flow diagram of an exemplary ad fetch process according to the present invention, and 
Fig. 1. First, the client software running on client computer 100a identifies itself to the 
PlayList server 302, e.g., ads.eudora.com. The client software, e.g., the Eudora software, 
provides to the PlayList server 302 basic client information and the ID of the PlayList the 

15 client software currently has installed. The ads.eudora.com server responds with either an 
indication that the current PlayList is still valid, uses an Hyper Text Transfer Protocol 
(HTTP) redirect to send the client to a different PlayList server, e.g., another PlayList server 
302', or responds directly with the New PlayList from PlayList server 302. See Fig. 14. In 
the event that the New PlayList is received from PlayList server 302, the client software 

20 compares the New PlayList with its current set of ads, and begins fetching ads not resident in 
the e-mail client's ad cache from one of more ad servers, e.g., the ad server 303 illustrated in 
Fig. 1, according to URNs included in the PlayList. The client software also deletes ads not 
currently appearing in the PlayList. 

25 Advantageously, the client software performs a check for a New PlayList every three 

days. It should be mentioned that the 3 day interval between PlayList checks is arbitrary and 
applicable only to the exemplary preferred embodiments of the present invention being 
discussed. It should also be mentioned that the ads preferably will be fetched as needed to fill 
the PlayList, possibly over many mail checks. Moreover, the ad fetch process will be limited 

30 to one minute per mail check, irrespective of the tasking of either the e-mail client software 
or the client computer 100a. After one minute, the client software will disconnect from the 
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ad server 303. This will often mean that the e-mail client software has not filled the PlayList 
when the ad fetch operation is terminated. This is acceptable. The software will utilize the 
available ads while the remaining ads are being downloaded. 

5 Furthermore, the software provider advantageously can provide for multiple servers 

on a peer with ads.eudora.com server 303. It will be appreciated that these servers will 
provide extra ads for some Eudora user communities, e.g., all of the users at a company 
serviced by one ISP, etc. Stated another way, an ISP which provides additional services such 
as local and long distance telephone access may wish to cross promote these services to its 
10 own customer base. Thus, the ISP advantageously can contract for such localized promotion. 
The PlayLists transmitted to the ISP's branded Adware e-mail clients would be linked to an 
ad server 303" maintained by the ISP in that instance. 

Given a set of available ads, the software still needs to choose which ad to display 
15 next. It will be appreciated that this is a matter of much excitement in the Web ad industry, 
where many choices are allegedly made to maximize the profit of the advertiser. In 
particular, ads that generate better user response are preferred because such ads generate extra 
revenue - such ads are frequently tied to the content of the Web page upon which they are 
displayed. However, it is unlikely that either the software provider or the client software will 
20 be able to derive a significant benefit from the ad scheduling algorithms currently run on ad 
services. This is in part due to the fact that the ads being displayed by the e-mail client 
software are divorced from the content being displayed, i.e., neither the software provider nor 
the client software are cognizant of the content of any particular ad that the user is looking at, 
and in part due to the fact that the e-mail client software will be requesting ads in a batch for 
25 later display, rather than requesting them in "real time". 

As mentioned above, the PlayLists provide certain global inputs to the ad scheduling 
algorithm, including the parameters listed in the table immediately following. 
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DAD A A/JT7 r TI7X> 
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FaceTimeQuota 


The amount of time per day that the e-mail client software is supposed 
to show the ad. 


Rerunlnterval 


The age beyond which ads should not be "rerun" after the "runout", 
i.e., maximum permissible, time is passed. 



In addition, the per-ad inputs in the PlayList associated with ad scheduling are set 
forth in the following table. 



PARAMETER 


DESCRIPTION 


ShowFor 


This is the number of seconds the ad should be shown for at any given 
time. This number might be small, like a TV ad (e.g., 30), or large, 
more like a billboard (e.g., 3600 for one hour, uninterrupted). 


ShowForMax 


Maximum total amount of time to show this ad. The ad is exhausted 
after this time, and should be discarded once new ads arrive. 


DayMax 


Maximum number of times per day to show this particular ad. 


BlackBefore 


The amount of time the ad window should be blank before the ad is 
displayed. 


BlackAfter 


The amount of time the ad window should be blank after the ad is 
displayed. BlackAfter runs concurrently with the blackBefore of the 
next ad, so that the actual time between ads is max(blackAfter, 
blackBefore), not blackAfter + blackBefore. 


StartDT 


Date/time (time zone optional) before which the ad should not run. 


EndDT 


Date/time (time zone optional) after which the ad should not run. 
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There are some values the software provider computes that are also input to the 
scheduling algorithm. These global values are listed in the table which follows. 



PARAMETER 


DESCRIPTION 


AdFaceTimeToday 


The total amount of ad Face time for the current day during which 
regular ads have been shown. 


TotalFaceTimeToday 


The total amount of Face time for the current day. 



5 The software also keeps track of and reports these values to the software provider for 

every ad: 



PARAMETER 


DESCRIPTION 


NumberShownToday 


The number of times an ad has been shown on the current day. 


ThisShowTime 


The amount of face time the current ad has received. 


LastShownDate 


The last date/time that the e-mail client software showed this ad. 



Advantageously, the software provider implements three major states of the ad 
10 scheduler, the regularState, the runoutState, and the rerunState. In the regularState, the e- 
mail client software advantageously is showing regular ads and accounting for them. It will 
be appreciated that this is what actually generates charges for the bulk of the ads displayed on 
the e-mail client. In contrast, the runoutState is selected when the e-mail client software has 
shown enough regular ads to fill the assigned faceTimeQuota, and the ad cache includes one 
15 or more runout ads available for showing. In the rerunState, the e-mail client software has 
exhausted both its regular ad quota and the runout ads, i.e., the e-mail client software is now 
reshowing the regular ads, but the software provider is not charging for them. 

It should be mentioned here that the software provider advantageously can provide a 
20 custom installer to various ISPs, book publishers, etc., that will label or brand the copies of 
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Eudora that they have distributed. The software provider will then credit these distributors 
with a percentage of the ad revenue generated by the clients they distribute. It will be 
appreciated that these credits may be offset by cross promotional activities associated with 
each branded version of the Adware e-mail client, for the reasons previously discussed. 

5 

Given the discussion presented immediately above, a more detailed explanation of 
various aspects of the exemplary e-mail client software according to the present invention can 
now be provided. 

10 As previously noted, the PlayList is a way to control the fetching and display of ads in 

software, e.g., in the Eudora e-mail client. The primary benefits associated with the PlayList 
are the separation of ad parameters from ad images, insulation of the Eudora client from 
intimate knowledge of ad image servers, and centralized server intelligence in ad distribution, 
without requiring user registration or centralized user databases. Thus, it will be appreciated 

15 that PlayLists are extremely malleable objects. In an exemplary case, the PlayLists can exert 
varying degrees of control over how the Eudora client behaves, from specifying the exact set 
of ads Eudora runs to simply transmitting abstract URNs which will choose their own ads. If 
PlayLists are used to their fullest advantage, they will give the software provider a powerful 
tool in controlling ad display in software such as Eudora; if PlayLists are later deemed 

20 irrelevant, the PlayLists cost the software provider one extra, brief network connection per 
day. 

As discussed above with respect to Figs. 1 and 14, the client computer 100a connects 
to a PlayList server 302 (which may redirect to a different server 302*) via a network 200. 
25 Then, the PlayList server 302 returns a PlayList to the client computer 100a via the network 
200. Subsequently, the e-mail client software on the client computer fetches the ads specified 
in the PlayList. 

The PlayList Request, which is sent by the Eudora client to the PlayList server 302 in 
30 order to initiate the ad fetch process, is not a simple burst of binary code. The PlayList 
Request is a block of extensible markup language (XML) code employed to provide the 
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server 302 with sufficient information to build or select the proper New PlayList for the user. 
The information in the PlayList Request is shown in the following table. 



PARAMETER 


DESCRIPTION 


UserAgent 


This is a string identifying the application requesting the PlayList, its 
version number, and the platform on which it is running. 


PlayList(s) 


This identifies the PlayList(s) that the client is currently using. This may 
have multiple values if the client is working off more than one PlayList. 


Entry 


A list of the id's of the ads recently shown by this client. The entries are 
nested inside the PlayList to which they belong. 

Each entry can have zero or more of the following associated attributes 
or types (the number following the equal sign (=) indicates an 
exemplary value attached to the attribute which is used to achieve the 
description of the entry attributes provided below): 




Active="0" 


The ad is no longer being shown. 




IsRiraout='T' 


The ad is a runout ad. This saves the server 
having to do a lookup on the ad. 




IsSponsor='T' 


The ad is a sponsorship ad, to be shown in 
place of the QUALCOMM logo. See Fig. 3B. 




IsButton= T"' 


The ad is a toolbar button. 




Deleted= T" 


The ad has been hidden by the user. This is 
allowed only for toolbar ads. 
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FaceTime 


This lists the amount of face time the user has 
used in the last seven calendar days. This 
dJiuvvb Liie iscivci to ucLcrimiic now iiiaiiy a\Xo 
the client is likely to be able to display. The 
value for the current day is the greater of 
today's value (see faceTimeUsedToday) and 
last week's value for today. 




FaceTimeLeft 


This is a total of the amount of face time 
requested by the ads still left in the client's ad 
cache. 




FaceTimeUsedToday 


This is the amount of face time the client has 
used toward displaying ads today. It can be 
used by the server to determine whether a date- 
critical ad can be shown today. 




DistriDutorlU 


This id is used for the bounty system, so that 
the PlayList Server can identify and credit, 
commission or otherwise reward the ISP or 
other organization that distributed this copy of 
Eudora. 




Pastry 


This is a cookie the PlayList Server gave to the 
Eudora e-mail client in the past. It could 
contain any state information/settings the 
server wishes to save. 




Profile 


Profiling information originally entered on the 
software provider's web page and 
subsequently/concurrently stored with the e- 
mail client. 
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Screen.height 


The height of the display on which the ads are 
shown, in pixels. 




Screen.width 


The width of the display on which the ads are 
shown, in pixels. 




Screen.depth 


The color depth of the display on which the ads 
are shown, in colors/bits per pixel. 




PlayListVersion 


The version # of the PlayList routine employed 
by this particular client. 



It will be appreciated that not all of these parameters are likely to be actively used at 
the same time; some are present to support particular modes of operation (see below), and 
will not be used in other modes. It should be mentioned here that every PlayList Request is 
5 checksummed with MD5. See RFC1321 - "The MD5 Message-Digest Algorithm" at 
http://www.facs.org/rfcs/rfcl321.html. The PlayList server 302 preferably ignores requests 
that fail checksum verification. 

After the client makes a PlayList Request, the server 302 replies with a PlayList 
10 Response. Preferably, the PlayList Response is divided into two major sections; the 
Clientlnfo section, which updates general client behavior regarding ads, i.e., speed with 
which the ads turn over, and the New PlayList itself, which describes the ads the client should 
fetch. It should be mentioned that the PlayList Server, e.g., server 302, may also return an 
empty response, meaning that the e-mail client should continue on its course with the ads it 
15 already has. It should also be mentioned that every PlayList Response is checksummed with 
MD5, just as the PlayList Request is. The MD5 digest is encoded in hexadecimal and put in a 
"Checksum" header in the PlayList Response. Advantageously, the e-mail clients ignore 
PlayLists that fail checksum verification. 

20 Before describing the sections of the PlayList Response, it should be mentioned that 

the e-mail client sometimes becomes, for lack of a better term, befuddled due to old client 
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bugs, server bugs, etc. Sometimes the bad data inherited by even an updated client is too 
garbled for the system to function properly. While the client could be programmed to detect 
this condition, it is preferable to leave the task, i.e., error detection, to the server, which can 
be changed more easily. Thus, when the server detects that a client is "befuddled," the 

5 PlayList server 302 responds with just a single command: reset. No Clientlnfo should follow, 
no PlayList should follow, just the reset command. On receiving the reset command, the 
client discards its accumulated ad databases and records, including PlayLists, faceTime 
history, ad history, ad caches, etc. Everything is reset to the pristine condition that the e-mail 
client software had before the Adware software was run for the very first time. It should be 

10 mentioned that Link History is exempted from the reset command, both for reasons of 
practicality and because it is so user- visible. The only other item of ad data that reset does not 
affect is the ad failure counter, which should be retained across a reset. The client should then 
recognize that it has no PlayList, and make another request to the PlayList Server for the 
needed PlayList. 

15 

The Clientlnfo section updates various client parameters. The parameters are listed 
immediately below. 



PARAMETER 


DESCRIPTION 


Reqlnterval 


This is the number of hours the client should wait before checking for a New 
PlayList. If ad turnover is high, this will be a small number. A sponsored 
freeware version might have a much higher number here, so that it checked 
for a New PlayList only once a week or once a month. Clients may also check 
for New PlayLists if they have ads with nonzero showForMax values, and the 
ads have used up much of their time. 


Histlnterval 


This value is the number of days the client must remember that it showed a 
particular ad. It will report this to the PlayList server so that the server can, at 
its discretion, choose not to direct the showing of ads for competing services 
to that particular client, competing ads are separated from one another by the 
Histlnterval value. 
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Pastry 


The previously mentioned cookie. The server can store whatever state 
information it wishes in this cookie. 


Flush 


More command than parameter, if present, it causes the client to discard an 
old PlayList or ad. Flushed ads and PlayLists are removed completely, and no 
longer show up in ad histories. 


Width 


The width in pixels the client should make the ad window be. 


Height 


The height in pixels of same. 


FacetimeQuota 


The number of seconds of facetime the client should devote to regular ads, 
before moving to the runout ad. 


Rerunlnterval 


The number of days an ad may be "rerun"; that is, shown for free after all 
other ads and the runout are exhausted. The time is measured from the last 
non-rerun showing of the ad. 



From the discussion above, it will be appreciated that the Clientlnfo section is a 
powerful feature of PlayLists. It allows the software provider to control the application in a 
global way, including segueing smoothly from one ad model to another. It will be appreciated 
5 that if this were the only benefit the software provider derived from PlayLists, it alone would 
make implementation of PlayLists worthwhile. 

As mentioned above, the PlayList Response is divided into two major sections; the 
Clientlnfo section, which updates general client behaviors, and the New PlayList itself, which 

10 describes the ads the client should fetch. The New PlayList itself has one global value, 
PlayListlD. This id is the id value that the client returns to the PlayList server the next time 
the client computer 100a connects to the PlayList server 302. It will be appreciated that this 
PlayListlD advantageously can be included in the PlayList Request, or can be separately 
uploaded to the PlayList server in a myriad of forms, e.g., as a cookie. The remainder of the 

15 PlayList is a list of ads. Each ad is allowed to have many parameters, although it's likely not 
all of them will be used with any single ad, and it is possible that some of them will never be 
used at all. The parameters include the scheduling parameters, which are 
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described in detail above, and ad information, which includes the information listed 
immediately below. 



PARAMETER 


DESCRIPTION 


AdID 


A unique identifier for the ad in question. A 64-bit integer, the top 32 bits 
of which are a server authority id, the bottom 32 bits of which are an 
identifier unique to the server authority. 


Title 


A human-friendly string used to refer to the ad. 


Src 


A URN indicating where to get the actual ad to show. This might be highly 
specific (e.g., http://media48.doubleclick.net/eudora/coke/drinkcoke.gif) or 
it might be much more general 

(e.g., http://ads.doubleclick.net/eudora/ad; ord=l 36784421 ?). 
Another important PlayList feature is that the PlayList permits the client 
software to pull ads from many different servers. The software provider 
could, for example, run its own servers in parallel with those belonging to 
DoubleClick, and take ads from each server, or some of the servers, based 
on the PlayList. 

There can be a checksum attribute on the src tag. If present, its value is a 
hexadecimal-encoded MD5 digest of the ad data. The client may check this 
checksum against the ad data. 


IsButton 


Is this "ad" a toolbar button? If so, it will be scheduled separately from the 
main ads. The only scheduling parameters that are meaningful for toolbar 
buttons are startDT and endDT. 


IsSponsor 


Is this "ad" a sponsor placard? If so, it will be scheduled separately from 
the main ads. 


IsRunout 


Is this ad intended to be run after all other ads have exhausted their runs for 
a given day? There will only be one active isRunout ad in any client's 
collection of PlayLists. 
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URN 



The Uniform Resource Name of the server (e.g., a Web site address) to 
which the user is directed when he/she clicks on the ad. 



10 



It should be mentioned that the term Uniform Resource Name (URN) indicates a 
generic set of all names/addresses that are short strings that refer to resources available via 
the Internet. Thus, URN encompasses both a Uniform Resource Locator (URL), which is 
subset of URN schemes that have explicit instructions on how to access a particular resource 
on the Internet, and a Uniform Resource Identifier (URI), which is another subset of URNs. 
It will be appreciated that the URL and URI subsets may overlap. It will also be appreciated 
that the terms URN, URL, and URI advantageously can be used interchangably; whichever 
term is used is meant to address the named resource in its broadest possible sense. 



It has been mentioned in passing that not all parameters are likely to be used at one 
time. In fact, PlayLists are flexible enough to support many ad models. PlayLists are crucial 
to some ad models, to others they are helpful but not central, to still others they are 
marginally useful, but do not present significant impediments. The use of PlayLists does not 

15 predispose the software provider towards any specific ad model; the PlayLists 
advantageously can be used to support any ad models that the software provider chooses. 
Indeed, PlayLists permit the software provider to switch between ad models midstream, 
* should the software provider decide to do so. In the discussion that follows, several ad 
models will be discussed with respect to Figs. 16A and 16B in an effort to illustrate how 

20 PlayLists would be used for each ad model. It will be appreciated that this will demonstrate 
the essential neutrality of the PlayList concept to the ad model. 



Fig. 16 A illustrates the ad model associated with persistent ads while Fig. 16B depicts 
the parameters associated with a short-lived ad model. One thing to notice here is how few of 
25 the parameters from any of the sections appear in the chart. It will be appreciated that varying 
as few as five parameters advantageously causes the Adware to shift between these two 
distinct ad modes. That's because they are largely not relevant to the choice of ad model. The 
parameters will either be used or not, irrespective of the ad model. For example, the software 
provider can implement blank space after an ad in any model, and the software provider can 
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eschew blank space after an ad in any model. Most of the parameters fall into this it-just- 
doesn't-matter category. 

With respect to the short-lived ad model, it will be appreciated that the software 
5 provider accepts many ads; either from many advertisers or only a few advertisers. Ads do 
not persist for many days; they're used up and discarded at a relatively rapid rate. In this 
model, PlayLists will be used additively. Each time the client runs low on ads, it will ask for 
another PlayList which will describe a few more ads to mix with the clients' existing ads. 
When ads exceed their allotted time, the ads are discarded. In this ad model, the PlayList 
10 server really only serves to transmit parameters for ads. However, that is acceptable, since the 
parameters have to be transmitted somehow, after all. 

Suppose the software provider wants to mix ad models, e.g., desires to provide; a mix 
of long-running ads and short-lived ads. How this situation is handled depends on the 

15 stoichiometry. If the cache is or will be filled with mostly persistent ads and only a few short- 
lived ones, the software provider can merely increase the reqlnterval and use PlayLisIs as in 
the Persistent Ad Model. In other words, the software provider merely picks a few random 
ads to go on each PlayList, and picks a few more random ads to go on the next PlayList, 
which the client will fetch the next day. If, on the other hand, the cache will contain mostly 

20 short-lived ads and only a few persistent ads, the computer system 10 will use multiple 
PlayLists. One PlayList will list the persistent ads, as discussed above; the remaining 
facetime will be filled using PlayLists of short-lived ads. 

The above discussion illustrates how PlayLists can be used to support widely differing 
25 ad models. The reason PlayLists can do this is that they're really only an extra level of server 
control and in between Eudora and its ads. 

Given the importance of ads to Adware e-mail software, one of the software 
provider's key concerns is "what happens if the Adware does not receive ads?" For example, 
30 users or ISPs may simply shut off the flow of ads to Eudora by using firewalls or other 
means. Alternatively, the user may simply delete ads or Playlists (or both) from, for 
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example, his/her computer on a random or periodic basis. If this happens, then users wil have 
no ads to display, i.e., the users get the full-featured version of Eudora without either seeing 
ads or paying. This would defeat one significant aspect of the exemplary software according 
to the present invention. On the other hand, users may have hardware or software problems 
5 or other issues that keep them from fetching ads, or the software provider's ad servers, might 
even be down for some reason. Users should not be punished for this. 

The software provider will distinguish between these two situations by asking a 
simple question, i.e., is the user sending or receiving mail? If the answer is yes, the software 

10 provider will assume that the blocking of ads is something the software provider needs to 
address. The way the software provider addresses this issue is with an escalating series of Ad 
Failure Nags. These will continue for two weeks or until the software receives ads. For every 
two days the software does receive ads, the software will decrement the Ad Failure Nag timer 
by one day. If the timer runs out, the software will display an apology to the user, revert to 

15 the Freeware version, and mark the user's software as owned by a Deadbeat User. Deadbeat 
Users will only be allowed to return to Adware if the ad server can be connected to at the 
time the user attempts to return to Adware. See Figs. 17 A -17C. It should be noted that if the 
software provider should ever decide to retire Eudora and wish to let people use it without 
ads, the software provider can simply publish a permanent registration code. 

20 

Alternatively, the e-mail client advantageously includes several more sophisticated 
functions for determining that an ad failure condition requires the employment of the Ad 
Failure Nag discussed above. For example, the client device can identify an ad download 
failure condition when a corresponding ad download function has failed to downloads during 
25 a predetermined period of time. In addition, the e-mail client device can identify an ad 
display failure condition when a corresponding ad display function has failed to display ads 
for a predetermined time period, e.g., the time(s) specified in the New PlayList received from 
the PlayList server and/or the current PlayList(s) stored for use by the e-mail client device. 
Either condition invokes the Ad Failure Nag function discussed above. 

30 

One of the things the software provider will need to know is that the ads the software 
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provider thinks are being displayed are actually being displayed, thus confirming that the ads 
are being displayed as frequently and for as long as the software provider thinks they are 
being displayed. It will be appreciated that this will be crucially important to maintaining 
credibility with advertisers. An exemplary audit scheme contains the following features: 
5 • Keep a rotating log of ad displays. This log will be rolled over once per week. The 

log will record ad-related events— when an ad was displayed, when it was removed, 
and when it was clicked on— in addition to other events, like cumulative face time in 
Eudora, cumulative run time, etc. 

• At random, ask the user for permission to transmit the log. At a frequency of one 
10 out of every hundred users per month, ask for the user's permission to return the log 

to the software provider. If the permission is given, the log will be formatted in 
ASCII, placed in an outgoing message, and queued. The user will be given the 
opportunity to inspect and, if he/she desires, cancel the log collection. See Fig. 18 A. 

♦ For selected users, deliver a pastry. In addition to the random send of the log, the 
15 software provider will also, at random, ask particular users for their permission to 

audit transactions in detail with the server. This will allow the software provider to 
correlate client and server behavior. 

Additional details on instrumentation applicable to the exemplary Eudora e-mail 
20 client software is provided in Figs. 18B -18E. 

The various state flow diagrams illustrated, for example, in Figs. 5A, 6A, 7A, 8 and 9, 
referred to a plurality of web pages, i.e., HTML pages that can be accessed and retrieved 
from one of the software provider's servers, e.g., registration server 301. See Fig, 1. The 
25 general purposes of these pages and the URNs which the software uses to access these pages 
will now be described in greater detail below. 

It will be appreciated that it will be helpful for the client to give the server in! brmation 
to help the server direct the user to the proper location or to assist the user by prefilling 
30 certain items on Web page based forms. That is the function of the query part of the URNs. 
The elements that might go in query parts are listed below. It will be noted that the query 
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parts are divided into two groups. The first group includes items which are considered 
personal, and great care should be taken to transmit them only when appropriate; the second 
group includes items which are not considered to be privacy-sensitive. 



Realname 


The Real Name field from the user's Dominant e-mail personality. 
(EP4 supports multiple e-mail personalities for EMAP4 (both POP3) e- 
mail accounts.) 


Regfirst 


The first name under which the user registered last time (if any). 


Reglast 


The last name under which the user registered last time (if any). 


Regcode 


The user's current Eudora registration code (if any). 


OldReg 


The user's old-form RegCode. 


e-mail 


The e-mail address from the user's Dominant personality. 


Profile 


The profile information the user has entered. 


Destination 


This is the URN which the user wishes to visit. 


Adid 


This is the id of an ad on which the user clicked. 


Platform 


MacOS, Windows, Palm, Nintendo 64, etc. 




Product 


The software provider's code name for the product being registered. 
Eudora, PDQMail, etc. 


Version 


The version number of the product being used to register. This should 
be of the form Major.Minor.Bugfix.Build. 


DistributorlD 


This will be a code which sites may apply for, which will, in turn, 
allow the site, i.e., its controlling entities, to receive a continuing 
revenue stream in return for providing users with this custom-branded 
copy of Eudora. 
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Action 


What it is the user has requested to do; register, pay, lostcode, etc. 


Mode 


Either Payware, Adware, or Freeware. 


Topic 


Used for support items, this tells the server what particular kind of 
support is needed. 



Typically, all of the software provider's non-ad URNs begin with: 

http://iump.eudora.com/iumpxgi?action-whatever 



5 The "action" value determines what function the user wishes to perform. The software 

provider then appends various other query parts to the URN, suitably %-escaped, i.e., 
separated by a percentage (%) or ampersand (&) symbol (for example), according to the chart 
illustrated in Fig. 19. A brief discussion of each type of web page referenced in Fig. 19 is 
provided immediately below. 

10 



PAYMENT 
WEB PAGE 


This web page should take the user's credit card info, name, e-mail 
address, and whatever other information the software provider 
wants to compile about its users. It will also ask them for a 
question and answer for use if they ever lose their payment code. It 
should return, e.g., display and also e-mail, their official 
registration name and registration code. 


FREEWARE 
REGISTRATION 
WEB PAGE 


This web page should take the same info as the Payment web page, 
minus the credit card information. It should send back (that is, 
display and also e-mail) their official registration name and 
registration code. 


ADWARE 
REGISTRATION 
WEB PAGE 


This web page should take the same info as the Payment web page, 
minus the credit card information. It should send back (that is, 
display and also e-mail) their official registration name and 
registration code. 
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BOX REGISTRATION 
WEB PAGE 


This web page exists to accept registrations generated by Box or 
updater installers. It should simply accept the user's code, validate 
it, mail it back, and display a "thank you for registering" page or 
dialog box. 


LOST CODE 
WEB PAGE 


This web page helps users find their registration codes. When they 
register/pay, they'll be asked to provide their name, e-mail address, 
and a question and answer. When they come to the lost code page, 
they'll be asked for name and address, and if that matches, they'll 
be asked their question. If all that goes well, their RegCode will be 
mailed to them. If they can't receive mail, they'll have to call. 


UPDATE 
WEB PAGE 


This web page should list the updates that are available to the user. 
Ideally, it would list only those updates the user does not already 
have, and clearly indicate which updates are free and which 
updates the user needs to pay for. This web page will be 
downloaded to the user's system from time to time and displayed 
"off-line" in Eudora, and so it should be kept small. 


ARCHIVED VERSIONS 
WEB PAGE 


This web page should list all versions of Eudora, so that users can 
download whatever they happen to need. 


PROFILE WEB PAGE 


The purpose of this web page is to collect demographic 
information so that ads delivered to the user can more precisely 
targeted by advertisers. At this page, the user will be asked a 
series of questions about his/her personal preferences, habits, etc., 
e.g., buying habits, sleeping habits, preferences in clothing, etc. No 
information identifying the user is to be collected on this page! 
The information will be reduced to a cookie, mailed to Eudora and 
stored as part of the user's settings in the Eudora directory (folder). 
The procedure for accepting a profile is the same as the procedure 
for accepting a registration code, detailed below. 
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SUPPORT WEB PAGES 


The software provider will need several web pages for resolving 




user problems. For these pages, the software provider will use the 




"topic" part of the query to direct users to situation-specific help as 




needed. 



Having discussed the client side of the overall system illustrated in Fig. 1, is it now 
time to turn to the server side of the system. The network will not be discussed in detail, 
however, as it is something well known in the art. 

In particular, the PlayList Server (PLS) or Servlet, i.e., the applet responding to the 
PlayList Request, shall now be described in detail. The PLS is a server side program which 
services HTTP requests and returns HTTP responses. It will be appreciated that each request 
launches a different thread, and that the data format of communications between the client 
and the PLS is XML-encoded in the exemplary embodiment. The PLS advantageously can be 
instantiated using the following Java packages. 



PKG 


DESCRIPTION 


USAGE 


XP 


XP is an XML 1.0 parser written in Java. 
The parser checks a given XML 
document for well-formedness and 
validity. Additional information is 
available from 

http://www.jclark.com/xml/xp/. 


The PLS uses the XP parser for: 

1. parsing the client request to 
ensure that it is valid. 

2. parsing the PlayList Response 
to ensure that it is valid 
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SAX 


SAX (Simple API for XML) is a standard 


The PLS uses the SAX interface 




interface for event-based XML parsing, 


both in the XML request and the 




the parser reads the XML document line 


XML response. In the request, 




by line and initiates events that contain 


the PLS "looks" for specific tags 




information about the line that was just 


to build the request object. In the 




read. The PLS listens to particular events 


, 1 tvt 0 J jl 

response, the PLS sends events 
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MMLMySQL 


MM,MySQL is a Java Database 


The PLS use the JDBC methods 




Connectivity (JDBC) Type-4 driver, i.e., 


to: 1. Establish connection(s) to 




an all-Java driver that issues requests 


communicate with the database 




directly to the PlayList server database. It 


using JDBC. PLS first 




will be appreciated that this is the most 


establishes a connection through 




efficient method of accessing the 


the appropriate JDBC driver. 




database. The JDBC API is made up of 


The connection object can be 




classes and interfaces found in the 


used to perform all operations on 




Java.sql and Java.text packages. 


the given database.. In an 




Additional information is available at 


exemplary case, the PLS will 




http://www.worldserver.com/mm.mysql/ 


create a pool of connection 






objects during the Servlet 






initialization. 






2. Execute SQL statements and 






retrieve results the: PLS performs 






a SQL query to the database 






using both Statement and 






Prepared Statement objects. 



What follows is an explanation of task flow in the PLS when the Servlet doPost 
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method is invoked. See Fig. 20. The PLS parses the XML request and builds objects that 
represents the client update request. It will be noted that data access is performed using SAX. 
When logging the client request, the PLS stores the client request information in a so-called 
ClientUpdate table (not shown). 

5 

It will be appreciated that the PlayList Request can be received from a plurality of e- 
mail clients residing on the client computers generally denoted lOOn through any given day. 
When issuing the same SQL statement repeatedly, it will be appreciated that it is more 
efficient to use a Prepared Statement rather then generating a new Statement in response to a 
10 query. In the logging operation, the software provider advantageously can employ the 
following semantic to avoid repetitive Statement generation: 

PreparedStatement ps = conn.prepareStatement( T, INSERT INTO ClientUpdate (date, 
userAgent, PlayListId,Y) values (?, ?, ?, ?,..)"); 

15 

It should be mentioned that in generating a New PlayList, the Servlet advantageously 
can employ both SQL queries and programming filtering. It will also be appreciated that 
these processes are synchronized in order to prevent conflicts when accessing the database. 
Appropriate pseudo code of generating a PlayList is depicted in Figs. 21A and 21B. The first 

20 block of pseudo code in Fig. 21 A generates an ad list. It will be appreciated that the ad list 
generated by the first block of pseudo code holds all the image ads that are active and. can be 
delivered within a predetermined time frame. The second block of pseudo code listed in Fig. 
21 A calculates the time needed to deliver the ads. The third block of pseudo code, which is 
illustrated in Fig. 21B, determines additional ads which can be used to fill the available 

25 facetime. In other words, if the e-mail client software has remaining time to fill, the 
generated PlayList will automatically fill the available time with runout ads, i.e., find a run 
out ad which is not in the ads history and which also fits into the Goal show time left. 

When generating XML, it is often useful to generate comments, processing 
30 instructions, and so on. The package XP Writer provides a set of methods for creating 
specific kinds of nodes in the output XML code, i.e., file. The following is a short list of 
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methods PLS employs in generating the XML output. 

• Starts an element - start-tag 

• Ends an element - end-tag or close the current start-tag as an empty element. 

• Attribute add attributes to a tag name value pair format 

• Comments writes a comment 



The PLS stores the information generated in response to a request in two tables, a 
PlayList general response table, which holds the client info section and PlayList general 
information, and a PlayList specific response, which holds the entry section. It will be 
10 appreciated that the PLS advantageously can use the prepared statement API to optimize 
performance in response to a query. 

Referring again to Fig. 20, that figure illustrates a class diagram which 
advantageously describes the representation and rendering of the PlayList, as will as the 
15 PlayList Response. It will be appreciated that this class diagram includes repeated XML 
Write method calls; these method calls are employed by PLS to generate the XML tags 
associated with the PlayList. 

Turning now to Fig. 22, that figure illustrates the major PlayList Servlet Classes, 
20 which collectively define the PlayList Servlet. More specifically, the PlayList Request class 
handles the request and subsequently maps the XML request to the clientUpdate object while 
the PlayListResponse class handles the response and writes the clientUpdateResponse back to 
the client. In addition, the PlayListsGenerate class generates the PlayLists while the 
DBManager class handles the Data Base connection pool. Additional details are readily 
25 apparent from Fig. 22. 

It will be appreciated from Fig. 23 that all of the storage operations employing the 
database advantageously can be threaded. As mentioned above, all actions with respect to the 
database are performed the MM.MySQL package. 

30 

In summary, one exemplary embodiment of the present invention encompasses 
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software for converting a general purpose computer into a specialized PlayList server for 
supplying a PlayList Response to a client device for exchanging information with an 
information server system over a communications network and storing ads. More 
specifically, the software instantiates a PlayList Response generation function for generating 
5 a PlayList Response identifying a plurality of selected ads to be presented by the client 
device, and a first communications function that completes a PlayList Response send 
communication link with the client device via the communications network over which the 
PlayList Response is transmitted to the client device, wherein the information server system 
and the PlayList server are independently controlled. It will be appreciated that, while the 
U 10 PlayList directs the presentation, e.g., display, of ads on the client device, e.g., an e-mail 
%J client, the ads advantageously may be delivered to or retrieved by the client device in any 
:5 number of ways in this preferred embodiment. In this exemplary embodiment, the PlayList 
Request preferably includes ad identifiers and ad presentation instructions; corresponding 
uniform resource names (URNs) can be included but may be omitted. 

i: rJ According to another exemplary embodiment, the present invention encompasses 

□ software for converting a general purpose computer into a specialized PlayList server for 

supplying a PlayList Response to a client device exchanging information with an information 
server system and receiving ads from an ad server over a communications network. The 
20 software advantageously includes a PlayList Response generation function for generating a 
PlayList Response identifying a plurality of selected ads to be presented by the client device, 
and a first communications function that effects a PlayList Response send communication 
link with the client device via the communications network over which the PlayList Response 
is transmitted to the client device. Preferably, the information server system and the PlayList 
25 server are independently controlled. It will be appreciated that this exemplary and non- 
limiting embodiment of the present invention contemplates a specific communications 
channel between the client device and a dedicated ad server (system) for delivery of ads 
defined by the PlayList. It will also be appreciated that the PlayList Request employed by 
this exemplary embodiment includes both information dictating presentation of the ads and/or 
30 operation of the client device with respect to ad presentation functions, and the name and 
URN for ads included in a New PlayList. 
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According to yet another exemplary embodiment, the present invention provides 
software for converting a general purpose computer into a specialized PlayList server for 
supplying a PlayList Response to a client device exchanging information with an information 
5 server system and receiving ads from an ad server over a communications network, 
including: 

• a PlayList Response generation function for generating a PlayList Response 
identifying a plurality of selected ads to be presented by the client device, 

• a PlayList Request parsing function for extracting selected information from the 
=010 PlayList Request; 

y • a PlayList generation function receiving an output of the database driver function 

j2[ for generating a PlayList for inclusion in the PlayList Response which identifies a plurality of 
W selected ads to be presented by the client device in response to receipt of a PlayList Request, 

• a selected information supply function for supplying the selected information to 
^4 15 the PlayList Response generation function to thereby initiate the PlayList generation function, 
: j • a first communications function that effects a PlayList Response send 
r3 communication link with the client device via the communications network over which the 
^ PlayList Response is transmitted to the client device, and 

• a second communication function that effects a PlayList Request receive function 
20 with the client device via the communications network, 

wherein the information server system and the PlayList server are independently 
controlled. 

Preferably, the PlayList Request parsing function includes an extensible markup 
25 language (XML) parsing function for verifying the wellformedness of the PlayList Request, a 
PlayList analysis function receiving the PlayList Request after verification by the XML 
parsing function for generating an object, and a database driver function receiving the object 
for building a query from the object and applying the query to a PlayList server database. 

30 It should be noted that the PlayList Response generation function is initiated by 

receipt of a PlayList Request, which, in an exemplary case, includes the name of the current 
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PlayList(s) employed by the client device providing the PlayList Request. While each of the 
numerous client devices connected to an information server generate a PlayList Request, the 
discussion of this specific aspect of the present invention, i.e., the PlayList server, can best be 
understood from the point of view of a system including only one client device; the actual 
implementation of the, for example, e-mail client device contemplates the use of thousands of 
client devices. 

The PlayList Request advantageously can include information regarding the currently 
running PlayList(s) on the client device, and user data fields that store data regarding the 
progress made by the client device in presenting, e.g., displaying, the ads stored by the client 
device. An exemplary and non-limiting list of the information that can be provided to the 
PlayList server via the PlayList Request includes: 

• a first user data field identifying a current PlayList; 

• a second user data field identifying user demographic data; 

• a third user data field identifying user/client device behavior data; 

• a fourth user data field identifying usage history of the client device; 

• a fifth user data field identifying the respective software operating on the client 

device; 

• a sixth user data field identifying the respective operating system of the client 

device; 

• a seventh user data field identifying the amount of time the user has used client 
device over a prescribed time interval; 

• an eighth user data field identifying the total amount of display time required for 
the stored ads that remain to presented by the client device; 

• a ninth user data field identifying the total amount of times that ads were 
presented by the client device during the prescribed time interval; 

• a tenth user data field identifying the dimensions of a display screen associated 
with the client device; and 

• a list of the ad identifiers corresponding to advertisements that have been 
displayed in the prescribed most recent time interval. 
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Advantageously, the PlayList Request parsing function can extract selected 
information from the PlayList Request and employ the selected information and other 
information, e.g., information provided by the entity controlling the PlayList server, in 
generating the PlayList Response. It will be appreciated that the PlayList Request may 
5 include all or a subset of the information listed immediately above; the PlayList Request 
parsing function extracts information contained in at least one of the user data fields. In any 
event, the receipt of the PlayList Request by the PlayList server initiates generation of the 
PlayList Response. 

10 In response to the PlayList Request, the PlayList Response generation function 

generates one of an action command and the PlayList Response. With respect to the former, 
the PlayList Response generation function advantageously can generate the action command 
in response to receipt of a garbled PlayList Request. This can be generally thought of as an 
error code directing the client device to send a New PlayList Request. It will be appreciated 

15 that the action command can include an associated error message, which is presentable to the 
user by the client device. Alternatively, the action command may cause the client device to 
delete all of the ads received and/or stored by the client device responsive to a command 
issued to the PlayList server by an entity controlling the PlayList server. In other words, 
there are times when the software provider may wish to flush the existing ads; the entity 

20 controlling the PlayList server, e.g., the software provider, sends a command to the PlayList 
server, which command causes the PlayList server to respond with a flush command, to either 
specific PlayList Requests, e.g., PlayList Requests generated by a particular software version, 
of all PlayList Requests. With respect to the latter, a detailed discussion follows. 

25 As discussed above, the PlayList Response advantageously includes both client 

information, information regarding how the client device, e.g., a PDA device, is to present, 
e.g., display, the selected ads, i.e., the ads that during the time period following receipt of the 
PlayList Response by the client device, and a New PlayList. For example., selected 
parameters included in the client information advantageously can switch the client device 

30 from between a persistent presentation mode and a short-lived presentation mode of 
presenting the ads. The client information can, in an exemplary case: 



-63- 



[PA000373] 

• control the turnover rate of the ads presented by the client device; 

• specify the periodicity at which the client device generates the PlayList Request; 

• establish a minimum time separation between competing ones of the ads; 

• establish specifications directing the manner in which the client device is to 
5 present each of the ads. 

For example, when the ads available to the client device include both current ads 
(paid ads) and expired ads (free ads), the client information includes a minimum time period 
during which the client device presents the current ads before the client device presents the 

10 expired ads. The client information may also establish a maximum time period during which 
the client device is permitted to present the expired ads. In any event, the PlayList Response 
advantageously may include commands or selected parameters which direct the client device 
to either concatenate the New PlayList to the current PlayList(s) or discard the current 
PlayList(s) in favor of the New PlayList. The command, or the selected parameters, 

15 controlling this facet of the client device operation is executed upon receipt of the PlayList 
Response by the client device over the effected communications link. 

The New PlayList included in the PlayList Response includes a name and a 
corresponding Uniform Resource Name (URN) for each of the selected ads. It will be 

20 appreciated that the URN can correspond to one of a storage location of the respective; named 
ad on an ad server or a location on the ad server redirecting the client device to a location on 
another storage device for the respective named ad. Alternatively, the URN specifies a 
location on the ad server redirecting the client device to an ad storage location collocated on 
the ad server for the respective named ad. It should be mentioned at this point that, in 

25 addition to the name and URN of each of the selected ads, the New PlayList may also include 
information identifying an ad type, i.e., postage stamp ad, toolbar ad, or placard ad, for each 
one of the respective selected ads. 

It should be noted that in at least one exemplary embodiment of the present invention, 
30 the PlayList server instantiated by software stored on the server computer 302 
advantageously responds to a PlayList Request written, i.e., coded, in extensible markup 
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language (XML). One of ordinary skill in the art of documents generated in XML will 
appreciate that these documents, e.g., the PlayList Request, advantageously can have an 
associated document type definition (DTD). In order to optimize system performance, the 
PlayList server should have the DTD available, i.e., available to the PlayList Request parsing 
5 function. There are several options for ensuring that the DTD is available to the PlayList 
server. First, the DTD for each of different types of client devices, e.g., e-mail client device 
or PDA, is stored by the PlayList server. In that case, the PlayList Request need only include 
a DTD tag, which identifies the particular DTD to be employed by the PlayList Request 
parsing function. Second, the DTD advantageously can be embedded in the PlayList 
10 Request. In either case, both the PlayList server and the client device implicitly use the same 
DTD. 

It should be mentioned that the software provider should make provisions with respect 
to ad security. There are really two security issues to consider. One is whether or not the 
15 client is getting valid ads (call this client security), and the second is whether or not a valid 
client is fetching ads (call this server security). 

Client security is of relatively small importance. If a given person manages, to trick 
Eudora into displaying some ads other than those transmitted by the software provider, it 

20 probably doesn't matter a great deal. This is not to say that it could not become problematic 
if large numbers of clients at one or more sites began doing it; however, a carefully worded 
license agreement should make at least large sites avoid actions which would cause this 
particular problem. However, to avoid trivial attacks, PlayLists and ads advantageously can 
be checksummed with MD5 (or another mechanism), and the checksums recorded in the 

25 PlayList. Then the client can checksum the PlayList and ads using the same secret seed, and 
compare its checksums to those in the PlayList. If it fails to get the proper ads, this will be 
treated as a failure to get ads at all. 

Server-side security is potentially a much bigger problem. The software provider 
30 intends to charge advertisers for ads, based on the understanding that the software provider's 
users will actually see the ads the software provider is charging for. To do this with 
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confidence, the software provider should ascertain that it is actually Eudora that is 
downloading the ads, and not some rogue process written to fetch many ads. Why would 
someone bother to fetch ads? While the software provider can't discount the "because they 
can" motivation of the amateur hacker, the real issue is the ad revenue, i.e., ad bounty. 
5 Because every ad fetch can generate revenue for a third party, there is a very significant 
financial incentive for that third party to cause a lot of ad fetches. It thus becomes imperative 
that the software provider prevent (and/or detect) ad fetches not made by copies of Eudora. 
Given that such fetches may be in violation of the agreement the software provider signed 
with the distributor, these fetches could constitute a form of fraud. 

10 

There are several different approaches to fraud detection which advantageously can 
be implemented in the software running, for example, on Ad server 303. Whatever method 
the software provider eventually uses to prevent fraud, it will be important also to- detect 
fraud should it occur. There are two broad classes of fraud detection; authentication and 
15 statistical analysis. 

Authentication is easily understood; if the program fetching the ads fails to prove that 
it is a valid copy of Eudora, the software provider will be alerted to possible fraud. However, 
authentication provides challenges of its own, and may be impossible or impractical or 
20 simply unnecessary. 

Statistical analysis has some significant benefits, but also significant drawbacks. The 
benefits include minimal work in the client (and hence no vulnerability to disassembly, etc.), 
no run-time burdens on either the client or the server, i.e., everything can be done "after the 
25 fact" during accounting runs, easily changeable from the software provider's end, ability to 
be applied retroactively, etc. The drawbacks to statistical analysis include that statistical 
analysis will never be entirely certain, and that the software provider may not collect the 
proper statistics, etc. 

30 A listing of parameters or statistical measures that the software provider may gather 

or compute is presented immediately below. 
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ClientID 


It's hard to see a way to avoid generating some sort of client id for use 
with fetching ads. The software provider might hope that such 
identifiers will be self-validating, but it is preferable that the software 
provider needs to know what particular installation of Eudora is 

OVlUcUly IC-lVlllllCj CtUo. 1I11& 111C11 UC UoCLl 111 ^UlllUlJLlIl^ oLdll&l Ito CU1U 

performing computations. By "installation" the software provider 
means a single storage system directory (PC) or folder (Mac) with a 
Eudora mail structure in it, i.e., data interchanged between the e-mail 
client and at least one server and not necessarily the e-mail client itself, 
per se. 


IpAddress 


The software provider will likely want to log requests by the IP address 
of the originating e-mail client. 


DistributorlD 


Of course a cornerstone of the referral payment system is the fact that 
the software provider will record the distributor ID for the client 
fetching ads. The software provider should collect this when users pay 
or even register the software. 


NumPaidUsers 


This statistic is the number of paid users with a given distributor ID. 


NumClientlDs 


This statistic is the number of client ID's with a given distributor ID. 


NumAdsFetched 


The number of ads fetched by a particular client ID. 



Given the raw data available from monitoring the parameters listed above, the 
following is an exemplary and non-inclusive list of possible statistical measures which can be 
generated. 



NumAdsFetched 



A client ID with a very high number of ads fetched is suspicious. 
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NumClientlDs/ 
NumPaidUsers 



Paid users is a very hard number, because the software provider will 
have collected credit card information and charged against this card. 
Thus, it can serve as a useful measuring stick for how many clients the 
software provider can expect. A particular distributor with a very high 
ratio or a ratio that suddenly goes higher bears investigation. 



One of the issues which the software provider must be very cognizant of is the 
protection of the user's privacy, i.e., the user generally does not want to receive ads based on 
information that the user unknowingly submitted to the software provider. There is an 

5 extremely vocal and paranoid subset of the user community, who object to practically all 
forms of information gathering, even the most benign. Even relatively innocent devices like 
serial numbers are considered something to be completely avoided. While the serial number 
of a software program may seem like a trivial matter to the software supplier, users who 
object to this type of "tagging" exist, and the software provider should be cognizant of such 

10 users. In order to avoid such concerns to the maximum extent possible; the software provider 
should adopt a Confidential Information Policy which includes the following provisions: 

• Obtain Permission - Before the software provider gathers or transmits any 
data that might identify the user to the advertiser, the software provider should obtain the 
user's explicit (See Fig. 18 A) or near-explicit permission. The term near-explicit is employed 

15 to denote that the software provider may, for example, put a special privacy warning in the 
web page where the user registers a software program such as Eudora. Here, the user is 
clearly taking an action to submit data to the software provider; as such, explicit permission 
shouldn't be needed. On the other hand, the software provider should go out of its way to 
identify areas where an unreasonable user might be able to claim that he/she didn't know 

20 he/she was giving information to the software provider, and ask for explicit permission there, 
even if it seems relatively obvious to the software provider. 

• Data Separation - Insofar as possible, the software provider should maintain 
payment information separate from registration information, and both types of information 
should be maintained separate from demographic information, etc. While it may be very 

25 tempting to correlate databases, the software provider faces potential crucifixion if the 
databases are actually correlated. Moreover, since the software provider can still deliver very 
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targeted advertising without database correlation, the software provider should maintain 
separate databases. 

• User Verifiability - Insofar as possible, protections established by the 
software provider should be verifiable by end users with packet sniffers. The software 

5 provider may even encourage the practice of watching the software's, e.g., Eudora's, actions. 
It is one thing to say "The software provider does not give your personal data to advertisers ;" 
it is quite another for the user to be able to verify that this is the case. 

• Strong Public and Private Commitment - The software provider needs to be 
clear and public with its privacy policies, and the software provider needs to respect them 

10 internally. If the software provider merely views privacy as something the software provider 
must do to avoid adverse press coverage, the software provider will do it poorly and wind up 
in trouble. 

In summary, the present invention encompasses a multi-moded software product, e.g., 
15 e-mail software, which includes three "self-contained" different versions (or, "modes"), 
including a "first full feature set" version which is activated when the software product is paid 
for by the user (i.e., a "Payware version"), a "second full feature set" version which is 
activated when the user agrees (e.g., either by default or by explicit agreement) to accept 
advertisements delivered to the client device in order to subsidize the software product (i.e., 
20 an "Adware" version), and a "reduced feature set" version which is activated when the 
software product is not paid for (i.e., a "freeware" version) and the "second full feature set" 
version is not activated. The present invention also encompasses a system and method for 
automatically distributing advertisements to a multiplicity of client devices that have such 
multi-moded software installed thereon. It will be appreciated that the first and second full 
25 feature sets are identical with respect to e-mail support features; it will also be appreciate that 
the second full feature set includes PlayList and ad fetching and display features which are 
dormant in the first full feature set. 

Moreover, the present invention further encompasses multi-moded software as set 
30 forth above, wherein the multi-moded software includes a mode switching function which 
automatically switches from the "Adware" version to the "freeware" version upon detecting a 



-69- 



r' 



[PA000373] 

prescribed condition (e.g., based upon monitored user activity level, and/or less than a 
prescribed number of ads having been downloaded, i.e., "deadbeat user" criterion). The 
present invention also encompasses a system and method for automatically distributing 
advertisements to a multiplicity of client devices that have such multi-moded software 
5 installed thereon. 

It will be appreciated from the discussion above that the present invention further 
encompasses multi-moded software as set forth above, wherein the multi-moded software 
includes a mode switching function which automatically switches from the "Adware" version 

10 to the "freeware" version upon detecting occurrence of a prescribed "ad failure condition", 
e.g., less than a prescribed number of ads having been received and/or displayed by the client 
device within a prescribed time period, and an "Ad Failure Nag" function which monitors 
"time since last Nag" and which generates an "Ad Failure Nag" according to a "Nag 
Schedule" which is dynamically varied based on the monitored "time since last Nag" 

15 information and/or based on cumulative ad download/display statistics or information. The 
present invention also encompasses a system (and method) for automatically distributing 
advertisements to a multiplicity of client devices that have this multi-moded software product 
installed thereon. 

20 In one exemplary embodiment, the present invention further encompasses multi- 

moded software as set forth above, wherein the multi-moded software includes a Nag 
function which generates different types of Nags dependent upon the current mode of the 
software product which is currently activated, and/or based upon time since the last Nag was 
generated, and/or based on cumulative ad download/display statistics or information, and/or 

25 based on other monitored conditions. For example, the different types of Nags could include 
a "Registration Nag", a "Payware Nag", an "Adware Nag", an "Update Nag", and an "Ad 
Failure Nag". The present invention also encompasses a system (and method) for 
automatically distributing advertisements to a multiplicity of client devices that have this 
multi-moded software product installed thereon. 

30 

In another exemplary embodiment, the present invention encompasses a software 
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product (e.g., e-mail software) that incorporates an automatic advertisement download 
function for automatically downloading advertisements to be displayed when the software is 
activated, and a control function for monitoring user activity levels and for controlling the 
display of downloaded advertisements at the client device based upon the monitored user 
5 activity levels (e.g., based upon "discrete" and/or "cumulative" ad display parameters). The 
present invention also encompasses a system and method for automatically distributing 
advertisements to a multiplicity of client devices that have this software product installed 
thereon. 

10 The present invention also encompasses an e-mail software product that incoiporates 

a control function for automatically downloading advertisements from a remote server system 
which is separate and independent from the e-mail server system, as well as the system and 
method for automatically distributing the advertisements to client devices which have' this e- 
mail software product installed thereon. In particular, the system includes an ad server 

15 system that manages, administers, and controls the distribution of advertisements, and which 
is controlled by a control entity (e.g., one operated by the present assignee, QUALCOMM 
INCORPORATED) which is separate and independent from the control entity which controls 
the e-mail server system which provides e-mail services to any particular client device which 
has this e-mail software product installed thereon. Thus, in sharp contrast to the Juno Online 

20 Services system, in accordance with this aspect of the present invention, the ad server system 
and the e-mail server system are operated independently, i.e., under the control of separate 
and independent control entities. 

Advantageously, the present invention also encompasses a software product, e.g., e- 
25 mail software, which incorporates an automatic advertisement files download function for 
automatically downloading advertisements from a remote server system to a client device on 
which the software product is installed, and a control function for locally controlling the 
display of downloaded advertisements at the client device based upon ad parameters included 
in the downloaded advertisement files, e.g., including (for each ad), various combinations and 
30 sub-combinations of the following ad parameters, namely, the maximum ad display time, or 
face time, for any given display of that particular ad, the maximum total/cumulative ad 
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display time, or face time, for that particular ad, the maximum number of times to display 
that particular ad per day, the date/time before which that particular ad should not ran, and 
the date/time after which that particular ad should not run. The present invention also 
encompasses a system and method for automatically distributing advertisements to a 
5 multiplicity of client devices that have this software product installed thereon. 

It will be appreciated that the present invention also encompasses a software product, 
e.g., e-mail software, which incorporates an automatic advertisement download function 
which fetches a PlayList from a remote server system (e.g., a PlayList server system) which 

10 specifies the advertisements to be fetched by the client device on which the software product 
is installed and the source addresses (e.g., URNs) of the ad servers on which the specified 
advertisements are stored, fetches the advertisements specified in the fetched PlayList, and 
stores the fetched advertisements on the client device. The present invention further 
encompasses a system and method for distributing advertisements to client devices which 

15 have this software product installed thereon, including a PlayList server (or PlayList server 
system) which, in response to a PlayList Request from a particular client device that includes 
a client PlayList identifier, compares a client PlayList identified by the client PlayList 
identifier with a current PlayList (which may optionally be customized to that particular 
client device) stored on the PlayList server, and then sends back to the client device a New 

20 PlayList which specifies the new advertisements to be fetched by the client device, and the 
source addresses of the ad servers on which the specified new advertisements are stored. 

Optionally, the above-described automatic advertisement download function of the 
software product installed on the client device can delete (discard) all or PlayList server- 

25 specified ones of the advertisements which are currently stored on the client device, e.g., 
those which are not specified in the current PlayList; and/or the above-described automatic 
advertisement download function of the software product installed on the client device can 
merge the New PlayList with the current client PlayList. The present invention also 
encompasses several variations and details of implementation of this novel PlayList/ad fetch 

30 process utilized in the Eudora Adware scheme. 
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Moreover, the present invention encompasses a software product, e.g., e-mail 
software, which incorporates a custom installer which identifies the specific software product 
distributor that distributed that software product. The present invention further encompasses 
a software product, e.g., e-mail software, which incorporates an automatic advertisement 

5 download function for automatically downloading advertisements from a remote server 
system to a client device on which the software product is installed, and a custom installer 
which identifies the specific software product distributor which distributed that software 
product, for the purpose of facilitating apportionment of advertising revenue the software 
product vendor receives from advertisers to specific software product distributors. The 

10 present invention also encompasses a system (and method) for automatically distributing 
advertisements to a multiplicity of client devices which have this software product installed 
thereon, wherein the system includes a centralized control facility which receives software 
product distributor ID information from the client devices and uses this software product 
distributor ID information to facilitate apportionment of advertising revenue the software 

15 product vendor receives from advertisers to specific software product distributors. 
Alternatively, or additionally, a central database function which identifies (e.g., by means of 
cross-referencing and/or correlation tables) the software product distributor ID for each 
software product distributed by the software vendor, e.g., based on a serial number or 
reference code associated with each copy of the software product, can be utilized. 

20 

Furthermore, the present invention encompasses a software product, e.g., e-mail 
software, that incorporates an automatic advertisement download function for automatically 
downloading advertisements from a remote server system to a client device on which the 
software product is installed, and a control function which utilizes a built-in "deadman timer" 
25 to impose a time limit for each particular advertisement download session, e.g., the client 
device will be disconnected from the remote server system upon expiration of the time limit 
imposed by the "deadman timer". The present invention also encompasses a system (and 
method) for automatically distributing advertisements to a multiplicity of client devices that 
have this software product installed thereon. 

30 

It will also be appreciated that the present invention can be characterized as a software 
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product, e.g., e-mail software, that incorporates an automatic advertisement download 
function for automatically downloading advertisements from a remote server system to a 
client device on which the software product is installed, and an instrumentation and auditing 
module having various novel features/functions, e.g., maintaining a rotating log of ad-related 

5 statistics and/or performing random and/or statistically-based ad effectiveness audits with 
user permission. The present invention also encompasses a system (and method) for 
automatically distributing advertisements to a multiplicity of client devices that have this 
software product installed thereon, wherein the system includes a centralized control facility 
for obtaining ad-related statistical information from selected client devices, in a random or 

10 statistical manner, e.g., for the purpose of monitoring the integrity and/or effectiveness of the 
advertisement distribution system. 

Moreover, the present invention encompasses a software product, e.g., e-mail 
software, that incorporates an automatic advertisement download function for automatically 

15 downloading advertisements from a remote server system to a client device on which the 
software product is installed, and a "link history" function which enables the user to review 
previously-viewed advertisements, e.g., by providing a graphical user interface (GUI) which 
includes a link history window that lists links the user has previously visited and ads that 
have been previously displayed to the user, along with some status information on each. 

20 Preferably, a mechanism will be provided to enable the user to select an ad listed in the link 
history window for display, e.g., by single-clicking the appropriate ad link, and to enable the 
user to visit the source Web site of any given ad listed in the link history window, e.g., by 
double-clicking the appropriate ad link. The present invention also encompasses a system 
(and method) for automatically distributing advertisements to a multiplicity of client devices 

25 that have this software product installed thereon. 

Furthermore, the present invention encompasses a software product, e.g., e-mail 
software, which incorporates a "Nag" function that monitors "time since last Nag" and that 
"nags" the user according to a "Nag Schedule" which is dynamically varied based on the 
30 monitored "time since last Nag" information. 
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Finally, the present invention encompasses a software product, e.g., e-mail software, 
that incorporates a download function that downloads separate file portions representing a 
single image during separate communication sessions with a remote server (e.g., separate file 
portions of an advertisement file, e.g., a GIF file). The present invention further encompasses 
5 a system (and method) for automatically distributing advertisements to a multiplicity of client 
devices that have this software product installed thereon. 

Although presently preferred embodiments of the present invention have been 
described in detail hereinabove, it should be clearly understood that many variations and/or 
10 modifications of the basic inventive concepts herein taught, which may appear to those 
skilled in the pertinent art, will still fall within the spirit and scope of the present invention, as 
defined in the appended claims. 
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WHAT IS CLAIMED IS: 

1. Software for use on a client device that is configured for communications with at 
2 least one remote source of advertisements via a communications network, comprising: 

an advertisement download function that downloads advertisements from the at least 
4 one remote source, during one or more advertisement download sessions; 

an advertisement storage function that stores the downloaded advertisements on a 
6 storage medium associated with the client device; 

an advertisement display function that effects display of at least selected ones of the 
8 stored advertisements on a display associated with the client device; 

an audit function that compiles ad-related statistical data relating to the downloaded 
10 advertisements, wherein the ad-related statistical data includes display event-related data 

regarding advertisements that were displayed during a prescribed audit interval; 
12 an audit data transmit function that transmits the ad-related statistical data to a 

prescribed server system, 

14 wherein: 

the audit data transmit function generates a send audit data display window 
16 that requests the user's permission to transmit the ad-related statistical data to the prescribed 
server system; and 

15 the audit data transmit function transmits the ad-related statistical data only in 
response to a user's grant of permission to do so. 

2. The software as set forth in Claim 1, wherein the ad-related statistical data 
2 facilitates analysis of the effectiveness of the software regarding presentation of 

advertisements to the user. 

3. The software as set forth in Claim 1, wherein the display event-related data 
2 includes display time data for advertisements that were displayed during the prescribed audit 

interval. 

4. The software as set forth in Claim 1, wherein the ad-related statistical data is 
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maintained as a log that is rotated at prescribed rollover intervals. 

5. The software as set forth in Claim 4, wherein the prescribed rollover intervals 
correspond to the prescribed audit intervals. 

6. The software as set forth in Claim 1, wherein the audit data transmit function is 
activated in response to a send audit data request transmitted by the prescribed server system. 

7. The software as set forth in Claim 6, wherein: 

the prescribed server system includes an auditing manager function; and 
the auditing manager function generates the send audit data request in accordance 
with a client auditing policy under which send audit data requests are transmitted to a 
statistical sampling of a population of client devices, at prescribed times. 

8. The software as set forth in Claim 6, wherein: 

the prescribed server system includes an auditing manager function; and 

the auditing manager function generates the send audit data request in accordance 

with a client auditing policy under which send audit data requests are transmitted to random 

ones of a population of client devices, at prescribed times. 

9. The software as set forth in Claim 1, further comprising a client information 
function that compiles client information that includes software usage data reflecting usage of 
the software by the user. 

10. The software as set forth in Claim 9, wherein the client information further 
includes user demographic data. 

11. The software as set forth in Claim 1, further comprising a client information 
function that compiles client information that includes user demographic data. 

12. The software as set forth in Claim 9, wherein the client information further 
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2 includes features of the software used by the user. 

13. The software as set forth in Claim 9, wherein the client information further 
2 includes user-selected settings. 

14. The software as set forth in Claim 10, wherein the client information further 
2 includes features of the software used by the user. 

15. The software as set forth in Claim 10, wherein the client information further 
2 includes user-selected settings. 

16. The software as set forth in Claim 9, further comprising a client information 
2 transmit function that transmits the client information to the prescribed server system. 

17. The software as set forth in Claim 10, further comprising a client information 
2 transmit function that transmits the client information to the prescribed server system. 

18. The software as set forth in Claim 12, further comprising a client information 
2 transmit function that transmits the client information to the prescribed server system. 

19. The software as set forth in Claim 13, further comprising a client information 
2 transmit function that transmits the client information to the prescribed server system. 

20. The software as set forth in Claim 16, wherein the prescribed server system and 
2 the at least one remote source are components of an advertisement distribution server- system. 

21. The software as set forth in Claim 20, wherein the advertisement distribution 
2 server system is managed by a producer of the software. 

22. The software as set forth in Claim 20, wherein the advertisement distribution 
2 server system is managed by a distributor of the software. 



-78- 



[PA000373] 



23. The software as set forth in Claim 1, wherein the communications network is the 
2 Internet. 

24. The software as set forth in Claim 1, wherein the software is e-mail software. 

25. The software as set forth in Claim 1, further comprising a custom installer 
2 function that generates a distributor identifier that identifies a distributor that distributed the 

software for use on the client device. 

26. The software as set forth in Claim 1, wherein the prescribed server system and the 
2 at least one remote source are components of an advertisement distribution server system. 

27. The software as set forth in Claim 26, wherein the advertisement distribution 
2 server system is managed by a producer of the software. 

28. The software as set forth in Claim 26, wherein the advertisement distribution 
2 server system is managed by a distributor of the software. 

29. The software as set forth in Claim 17, wherein the prescribed server system and 
2 the at least one remote source are components of an advertisement distribution server system. 

30. The software as set forth in Claim 29, wherein the advertisement distribution 
2 server system is managed by a producer of the software. 

31. The software as set forth in Claim 29, wherein the advertisement distribution 
2 server system is managed by a distributor of the software. 

32. The software as set forth in Claim 18, wherein the prescribed server system and 
2 the at least one remote source are components of an advertisement distribution server system. 
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33. The software as set forth in Claim 32, wherein the advertisement distribution 
2 server system is managed by a producer of the software. 

34. The software as set forth in Claim 32, wherein the advertisement distribution 
2 server system is managed by a distributor of the software. 

35. The software as set forth in Claim 19, wherein the prescribed server system and 

<■ 

2 the at least one remote source are components of an advertisement distribution server system. 

36. The software as set forth in Claim 35, wherein the advertisement distribution 
2 server system is managed by a producer of the software. 

37. The software as set forth in Claim 35, wherein the advertisement distribution 
2 server system is managed by a distributor of the software. 

38. The software as set forth in Claim 25, further comprising a client information 
2 function that compiles client information that includes the distributor identifier. 

39. The software as set forth in Claim 38, further comprising a client information 
2 transmit function that transmits the client information to the prescribed server system. 

40. The software as set forth in Claim 39, wherein the prescribed server system and 
2 the at least one remote source are components of an advertisement distribution server system. 

41. Software for use on a client device that is configured for communications with at 
2 least one remote source of advertisements via a communications network, comprising: 

an advertisement download function that downloads advertisements from the at least 
4 one remote source, during one or more advertisement download sessions; 

an advertisement storage function that stores the downloaded advertisements on a 
6 storage medium associated with the client device; 

an advertisement display function that effects display of at least selected ones of the 
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8 stored advertisements on a display associated with the client device; 

an audit function that compiles audit data including software usage data reflecting 
10 usage of the software by the user during a prescribed audit interval; 

an audit data transmit function that transmits the audit data to a prescribed server 
12 system, wherein: 

the audit data transmit function generates a send audit data display window 
14 that requests the user's permission to transmit the audit data to the prescribed server system; 
and 

16 the audit data transmit function transmits the audit data only in response to a 

user's grant of permission to do so. 



42. The software as set forth in Claim 41, wherein the audit data is maintained as a 
2 log that is rotated at prescribed rollover intervals. 

43. The software as set forth in Claim 42, wherein the prescribed rollover intervals 
2 correspond to the prescribed audit intervals. 

44. The software as set forth in Claim 41, wherein the audit data transmit function is 
2 activated in response to a send audit data request transmitted by the prescribed server system. 



45. The software as set forth in Claim 44, wherein: 

2 the prescribed server system includes an auditing manager function; and 

the auditing manager function generates the send audit data request in accordance 
4 with a client auditing policy under which send audit data requests are transmitted to a 
statistical sampling of a population of client devices, at prescribed times. 

46. The software as set forth in Claim 44, wherein: 

2 the prescribed server system includes an auditing manager function; and 

the auditing manager function generates the send audit data request in accordance 
4 with a client auditing policy under which send audit data requests are transmitted to random 
ones of a population of client devices, at prescribed times. 
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47. The software as set forth in Claim 41, wherein the audit data further includes 
2 features of the software used by the user during the prescribed audit interval. 

48. The software as set forth in Claim 41, wherein the audit data further includes user 
2 demographic data. 

49. The software as set forth in Claim 41, wherein the audit data further includes 
2 features of the software used by the user during the prescribed audit interval. 

50. The software as set forth in Claim 41, wherein the audit data further includes 
2 settings selected by the user during the prescribed audit interval. 

51. The software as set forth in Claim 41, further comprising a custom installer 
2 function that generates a distributor identifier that identifies a distributor that distributed the 

software for use on the client device. 

52. The software as set forth in Claim 52, wherein the audit data further includes the 
2 distributor identifier. 

53. The software as set forth in Claim 41, wherein the audit data further includes ad- 
2 related statistical data relating to the downloaded advertisements, 

54. The software as set forth in Claim 53, wherein the ad-related statistical data 
2 includes display event-related data regarding advertisements that were displayed during the 

prescribed audit interval. 

55. The software as set forth in Claim 53, wherein the ad-related statistical data 
2 facilitates analysis of the effectiveness of the software regarding presentation of 

advertisements to the user. 
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56. The software as set forth in Claim 54, wherein the display event-related data 
includes display time data for advertisements that were displayed during the prescribed audit 
interval. 

57. The software as set forth in Claim 54, wherein the ad-related statistical data 
further includes clickthrough data regarding each advertisement that was clicked on by the 
user during the prescribed audit interval. 

58. The software as set forth in Claim 53, wherein the ad-related statistical data 
includes clickthrough data regarding each advertisement that was clicked on by the user 
during the prescribed audit interval. 

59. The software as set forth in Claim 41, wherein the prescribed server system and 
the at least one remote source are components of an advertisement distribution server system. 

60. The software as set forth in Claim 59, wherein the advertisement distribution 
server system is managed by a producer of the software. 

61. The software as set forth in Claim 59, wherein the advertisement distribution 
server system is managed by a distributor of the software. 

62. The software as set forth in Claim 41, wherein the communications network is the 
Internet. 

63. The software as set forth in Claim 41, wherein the software is e-mail software. 

64. Software for use on a client device that is configured for communications with at 
least one remote source of advertisements via a communications network, comprising: 

an advertisement download function that downloads advertisements from the at least 
one remote source, during one or more advertisement download sessions; 

an advertisement storage function that stores the downloaded advertisements on a 
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storage medium associated with the client device; 

an advertisement display function that effects display of at least selected ones of the 
stored advertisements on a display associated with the client device; 

an audit function that compiles audit data including software usage data reflecting 
features of the software used by the user during a prescribed audit interval; 

an audit data transmit function that transmits the audit data to a prescribed server 
system, wherein: 

the audit data transmit function generates a send audit data display window 
that requests the user's permission to transmit the audit data to the prescribed server system; 
and 

the audit data transmit function transmits the audit data only in response to a 
user's grant of permission to do so. 

65. The software as set forth in Claim 64, wherein the audit data is maintained as a 
log that is rotated at prescribed rollover intervals. 

66. The software as set forth in Claim 65, wherein the prescribed rollover intervals 
correspond to the prescribed audit intervals. 

67. The software as set forth in Claim 64, wherein the audit data transmit function is 
activated in response to a send audit data request transmitted by the prescribed server system. 

68. The software as set forth in Claim 67, wherein: 

the prescribed server system includes an auditing manager function; and 
the auditing manager function generates the send audit data request in accordance 
with a client auditing policy under which send audit data requests are transmitted to a 
statistical sampling of a population of client devices, at prescribed times. 

69. The software as set forth in Claim 67, wherein: 

the prescribed server system includes an auditing manager function; and 

the auditing manager function generates the send audit data request in accordance 
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4 with a client auditing policy under which send audit data requests are transmitted to random 
ones of a population of client devices, at prescribed times. 

70. The software as set forth in Claim 64, wherein the audit data further includes user 
2 demographic data. 

71. The software as set forth in Claim 64, wherein the audit data further includes 
2 settings selected by the user during the prescribed audit interval. 

72. The software as set forth in Claim 64, further comprising a custom installer 
2 function that generates a distributor identifier that identifies a distributor that distributed the 

software for use on the client device. 

73. The software as set forth in Claim 72, wherein the audit data further includes the 
2 di s tributor identifier. 

74. The software as set forth in Claim 64, wherein the audit data further includes ad- 
2 related statistical data relating to the downloaded advertisements. 

75. The software as set forth in Claim 74, wherein the ad-related statistical data 
2 includes display event-related data regarding advertisements that were displayed during the 

prescribed audit interval. 

76. The software as set forth in Claim 74, wherein the ad-related statistical data 
2 facilitates analysis of the effectiveness of the software regarding presentation of 

advertisements to the user. 

77. The software as set forth in Claim 75, wherein the display event-related data 
2 includes display time data for advertisements that were displayed during the prescribed audit 

interval. 
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78. The software as set forth in Claim 75, wherein the ad-related statistical data 
2 further includes clickthrough data regarding each advertisement that was clicked on by the 

user during the prescribed audit interval. 

79. The software as set forth in Claim 74, wherein the ad-related statistical data 
2 includes clickthrough data regarding each advertisement that was clicked on by the user 

during the prescribed audit interval. 

80. The software as set forth in Claim 64, wherein the prescribed server system and 
2 the at least one remote source are components of an advertisement distribution server system. 

81. The software as set forth in Claim 80, wherein the advertisement distribution 
2 server system is managed by a producer of the software. 

82. The software as set forth in Claim 80, wherein the advertisement distribution 
2 server system is managed by a distributor of the software. 

83. The software as set forth in Claim 64, wherein the communications network is the 
2 Internet. 

84. The software as set forth in Claim 64, wherein the software is e-mail software. 

85. Software for use on a client device that is configured for communications with at 
2 least one remote source of advertisements via a communications network, comprising: 

an advertisement download function that downloads advertisements from the at least 
4 one remote source, during one or more advertisement download sessions; 

an advertisement storage function that stores the downloaded advertisements on a 
6 storage medium associated with the client device; 

an advertisement display function that effects display of at least selected ones of the 
8 stored advertisements on a display associated with the client device; 

an audit function that compiles at least two categories of audit data, including 
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software usage data reflecting features of the software by the user during a prescribed audit 
interval, and ad-related statistical data relating to the downloaded advertisements, wherein the 
ad-related statistical data includes display event-related data regarding advertisements that 
were displayed during the prescribed audit interval; 

an audit data transmit function that transmits one or more categories of the audit data 
to a prescribed server system, wherein: 

the audit data transmit function generates a send audit data display window 
that requests the user's permission to transmit each category of the audit data to the prescribed 
server system; and 

the audit data transmit function transmits only the category(ies) of the audit 
data for which the user has granted permission to transmit. 

86. The software as set forth in Claim 85, wherein the audit data is maintained as a 
log that is rotated at prescribed rollover intervals. 

87. The software as set forth in Claim 86, wherein the prescribed rollover intervals 
correspond to the prescribed audit intervals. 

88. The software as set forth in Claim 85, wherein the audit data transmit function is 
activated in response to a send audit data request transmitted by the prescribed server system. 

89. The software as set forth in Claim 88, wherein: 

the prescribed server system includes an auditing manager function; and 
the auditing manager function generates the send audit data request in accordance 
with a client auditing policy under which send audit data requests are transmitted to a 
statistical sampling of a population of client devices, at prescribed times. 

90. The software as set forth in Claim 88, wherein: 

the prescribed server system includes an auditing manager function; and 
the auditing manager function generates the send audit data request in accordance 
with a client auditing policy under which send audit data requests are transmitted to random 
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ones of a population of client devices, at prescribed times. 

91. The software as set forth in Claim 85, wherein the ad-related statistical data 
2 facilitates analysis of the effectiveness of the software regarding presentation of 
advertisements to the user. 



92. The software as set forth in Claim 85, wherein the display event-related data 
2 includes display time data for advertisements that were displayed during the prescribed audit 
interval. 



93. The software as set forth in Claim 85, wherein the ad-related statistical data 
2 further includes clickthrough data regarding each advertisement that was clicked on by the 

user during the prescribed audit interval. 

94. The software as set forth in Claim 85, wherein the prescribed server system and 
2 the at least one remote source are components of an advertisement distribution server system. 

95. The software as set forth in Claim 94, wherein the advertisement distribution 
2 server system is managed by a producer of the software. 

96. The software as set forth in Claim 94, wherein the advertisement distribution 
2 server system is managed by a distributor of the software. 

97. The software as set forth in Claim 85, wherein the communications network is the 
2 Internet. 



98. The software as set forth in Claim 85, wherein the software is e-mail softv/are. 



99. Software for use on a client device that is configured for communications, with at 
2 least one remote source of advertisements via a communications network, comprising: 

an advertisement download function that downloads advertisements from the at least 
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4 one remote source, during one or more advertisement download sessions; 

an advertisement storage function that stores the downloaded advertisements on a 
6 storage medium associated with the client device; 

an advertisement display function that effects display of at least selected ones of the 
8 stored advertisements on a display associated with the client device; 

an audit function that compiles a plurality of categories of audit data regarding 
10 activities of the user and/or client device during a prescribed audit interval; 

an audit data transmit function that transmits one or more categories of the audit data 
12 to a prescribed server system, wherein: 

the audit data transmit function generates a send audit data display window 
14 that requests the user's permission to transmit each category of the audit data to the prescribed 
server system; and 

16 the audit data transmit function transmits only the category(ies) of the audit 

data for which the user has granted permission to transmit. 

100. The software as set forth in Claim 99, wherein the audit data is maintained as a 
2 log that is rotated at prescribed rollover intervals. 

10L The software as set forth in Claim 100, wherein the prescribed rollover intervals 
2 correspond to the prescribed audit intervals. 

102. The software as set forth in Claim 99, wherein the audit data transmit function is 
2 activated in response to a send audit data request transmitted by the prescribed server system. 

103. The software as set forth in Claim 102, wherein: 

2 the prescribed server system includes an auditing manager function; and 

the auditing manager function generates the send audit data request in accordance 
4 with a client auditing policy under which send audit data requests are transmitted to a 
statistical sampling of a population of client devices, at prescribed times. 

104. The software as set forth in Claim 102, wherein: 
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2 the prescribed server system includes an auditing manager function; and 

the auditing manager function generates the send audit data request in accordance 
4 with a client auditing policy under which send audit data requests are transmitted to random 
ones of a population of client devices, at prescribed times. 

105. The software as set forth in Claim 99, wherein the prescribed server system and 
2 the at least one remote source are components of an advertisement distribution server system. 

106. The software as set forth in Claim 105, wherein the advertisement distribution 
2 server system is managed by a producer of the software. 

107. The software as set forth in Claim 105, wherein the advertisement distribution 
2 server system is managed by a distributor of the software. 

108. The software as set forth in Claim 99, wherein the communications network is 
2 the Internet. 

109. The software as set forth in Claim 99, wherein the software is e-mail software. 

110. The software as set forth in Claim 99, wherein the audit data comprises at least 
2 two of the following categories of audit data: 

software usage data reflecting features of the software used by the user during the 
4 prescribed audit interval; 

ad-related statistical data relating to the downloaded advertisements, wherein the ad- 
6 related statistical data includes display event-related data regarding advertisements that were 

displayed during the prescribed audit interval; 
8 user demographic data; and 

settings selected by the user during the prescribed audit interval. 

111. The software as set forth in Claim 1, further comprising an installer function for 
2 installing the software on a computer-readable storage medium. 
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112. The software as set forth in Claim 1, further comprising an installer function for 
2 installing the software on the client device. 

113. The software as set forth in Claim 1, further comprising an installer function for 
2 installing the software on a computer-readable storage medium associated with the client 

device. 



114. The software as set forth in Claim 41, further comprising an installer function 
2 for installing the software on a computer-readable storage medium. 

115. The software as set forth in Claim 41, further comprising an installer function 
2 for installing the software on the client device. 

116. The software as set forth in Claim 41, further comprising an installer function 
2 for installing the software on a computer-readable storage medium associated with the client 

device. 



117. The software as set forth in Claim 64, further comprising an installer function 
2 for installing the software on a computer-readable storage medium. 

118. The software as set forth in Claim 64, further comprising an installer function 
2 for installing the software on the client device. 

119. The software as set forth in Claim 64, further comprising an installer function 
2 for installing the software on a computer-readable storage medium associated with the client 

device. 



120. The software as set forth in Claim 85, further comprising an installer function 
2 for installing the software on a computer-readable storage medium. 
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121. The software as set forth in Claim 85, further comprising an installer function 
for installing the software on the client device. 

122. The software as set forth in Claim 85, further comprising an installer function 
for installing the software on a computer-readable storage medium associated with the client 
device. 

123. The software as set forth in Claim 99, further comprising an installer function 
for installing the software on a computer-readable storage medium. 

124. The software as set forth in Claim 99, further comprising an installer function 
for installing the software on the client device. 

125. The software as set forth in Claim 99, further comprising an installer function 
for installing the software on a computer-readable storage medium associated with the client 
device. 

126. The software as set forth in Claim 1, wherein the advertisement display function 
effects display of the at least selected ones of the stored advertisements when the client 
device is offline. 

127. The software as set forth in Claim 1, wherein the advertisement display function 
effects display of the at least selected ones of the stored advertisements while the user is 
composing and/or reading e-mail messages. 

128. The software as set forth in Claim 41, wherein the advertisement display 
function effects display of the at least selected ones of the stored advertisements when the 
client device is offline. 

129. The software as set forth in Claim 41, wherein the advertisement display 
function effects display of the at least selected ones of the stored advertisements while the 
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user is composing and/or reading e-mail messages. 



130. The software as set forth in Claim 64, wherein the advertisement display 
2 function effects display of the at least selected ones of the stored advertisements when the 

client device is offline. 

131. The software as set forth in Claim 64, wherein the advertisement display 
2 function effects display of the at least selected ones of the stored advertisements while the 

user is composing and/or reading e-mail messages. 

132. The software as set forth in Claim 85, wherein the advertisement display 
2 function effects display of the at least selected ones of the stored advertisements when the 

client device is offline. 

133. The software as set forth in Claim 85, wherein the advertisement display 
2 function effects display of the at least selected ones of the stored advertisements while the 

user is composing and/or reading e-mail messages. 

134. The software as set forth in Claim 99, wherein the advertisement display 
2 function effects display of the at least selected ones of the stored advertisements when the 

client device is offline. 

135. The software as set forth in Claim 99, wherein the advertisement display 
2 function effects display of the at least selected ones of the stored advertisements while the 

user is composing and/or reading e-mail messages. 

136. The software as set forth in Claim 1, wherein the audit data transmit function is 
2 activated randomly. 

137. The software as set forth in Claim 1, wherein the audit data transmit function is 
2 activated at random times. 
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138. The software as set forth in Claim 41, wherein the audit data transmit function is 
2 activated randomly. 

139. The software as set forth in Claim 41, wherein the audit data transmit function is 
2 activated at random times. 

140. The software as set forth in Claim 64, wherein the audit data transmit function is 
2 activated randomly. 

141. The software as set forth in Claim 64, wherein the audit data transmit function is 
2 activated at random times. 

142. The software as set forth in Claim 85, wherein the audit data transmit function is 
2 activated randomly. 

143. The software as set forth in Claim 85, wherein the audit data transmit function is 
2 activated at random times. 

144. The software as set forth in Claim 99, -wherein the audit data transmit fu action is 
2 activated randomly. 

145. The software as set forth in Claim 99, wherein the audit data transmit function is 
2 activated at random times. 

146. The software as set forth in Claim 1, wherein the ad-related statistical data 
2 further includes clickthrough data regarding each advertisement that was clicked on by the 

user during the prescribed audit interval. 
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ABSTRACT OF THE DISCLOSURE 

Software, for use on a client device that is configured for communications with at least 
one remote source of advertisements via a communications network, instantiates an 

5 advertisement download function that downloads advertisements from the at least one remote 
source, during one or more advertisement download sessions, an advertisement storage 
function that stores the downloaded advertisements on a storage medium associated with the 
client device, an advertisement display function that effects display of at least selected ones of 
the stored advertisements on a display associated with the client device, an audit function that 

10 compiles ad-related statistical data relating to the downloaded advertisements, wherein the ad- 
related statistical data includes display event-related data regarding advertisements that were 
displayed during a prescribed audit interval, and an audit data transmit function that transmits 
the ad-related statistical data to a prescribed server system. Advantageously, the audit data 
transmit function generates a send audit data display window that requests the user's 

15 permission to transmit the ad-related statistical data to the prescribed server system, and the 
audit data transmit function transmits the ad-related statistical data only in response to a user's 
grant of permission to do so. 
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///////////// /////////////////////// 

// Main ad scheduler 

ScheduleMain 

{ 

// Has a new day dawned? 
Do CheckForNewDay 

// Are we axe within the current ad's showFor? 

if ( ad.thisShowTime < ad.showFor ) 

{ 

// there is nothing to be done 

return 

} 

//At this point, we know that we need a new ad 
// Perform housekeeping tasks on the old one 
Do AdEndBookkeeping 

// Pop out of a block if all ads on par 

if { block isn't all playlists } 

{ 

find ad with minimum ad . number Shown 
if { ad + number Shown >» blockGoal ) 
set block to all playlists 
} 

// If we are over our quota of regular ads for the day, 
71 look for a runout 

if ( adFaceTimeToday > f aceTimeQuota } 
{ 

Do ShowARunout 
} 

else 
{ 

Do ShowAKegularAd 

} 
} 

// end ad schedule main 
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//////////////////////////////////// 

//We must: perform certain tasks when the calendar day 

changes • 

CheckForNewDay 

{if ( the calendar day has changed ) 
{ 

// Perform housekeeping tasks on the a d cur rently showing 
Do StopShowingCurrentAd 

// Runout ads are charged for a full showFor if they've been 
shown 

//at all on a given day. Charge amy runout ads if they've 
been 

// shown at all. 
for runout ads 
t 

if ( ad*this3howTime > 0 ) 
{ 

ad. tot alTiroe Shown += ad.showFor 

ad. this Showtime = 0 

> 

} 

// Now, reset the counters for all ads to reflect the fact 
that 

7/ a new day has dawned. 

for all ads 

{ 

ad* number ShownToday = 0 
> 

// Record yesterday's face time 

// Might not literally be yesterday, be sure to use 

// whatever day the app was last run on 

set old current day's face time to totalFaceTimeToday 

// and reset our global regular ad facetime counter 

adFaceTimeToday = 0 

totalFaceTimeToday » 0 

// if we were in a block, back out 

set block to all playlists 

} 

} 

// end CheckForNewDay 
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//////////////////////////////////// 

// This function shows a runout ad, and if it 
// can't find, one, goes to a rerun 
ShowARunout 
{ 

for runout ads 
{ 

// has the ad been flushed? 
if ( ad. flushed ) 
try next ad 

// are we done showing this runout today? 

if { ad. number ShownToday > ad* day Max ) 

try next ad // this one's used up for the day 

// are we done showing this runout for ever and ever? 

if ( ad . shownFor > a<3L „ showForMax } 

try next runout ad // this one's used up forever 

// are we between the ad's start and end dates? 

if C ad.startDate < the current date < ad.endDate ) 

try next runout ad 

// the ad is not supposed to run today 
// do we actually HAVE the ad? 
if ( ad has not been downloaded ) 
{ 

ask for ad to be downloaded 

try next ad 

} 

// ok, we believe we should show this runout 
// we are now in runout state 
Do ShowAnAd 
return 

} 

// if we haven't found a runout ad, we will go to "rerun 11 
state 

Do ShowARerun 
} 

// end ShowARunout 
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//////////////////////////////////// 

// Rerun state* Look for a regular ad to rerun 

ShowARerun 

{ 

for regular ads [ in current block ] 
{ 

// has the ad been flushed? 
if ( ad. flushed ) 
try next ad 

// is this ad recent enough to rerun? 

if ( ad. lastShownDate is older than retumlnterval ) 

try next ad 

// this one is too old to rerun 

// if in block, show ads only if it's their "turn" 

if ( ad. number ShownToday >= blockGoal ) 

try next ad // need to find a friend in this block 

// are we between the ad's start and end dates? 

if ( ad.startDate < the current date < ad*endDate ) 

try next ad 

// the ad is not supposed to run today 
// do we actually HAVE the ad? 
if (ad has not been downloaded ) 

{ 

ask for ad to be downloaded 
try next ad 

} 

// ok, at this point we can show this ad, but because 

// we're in rerun, we don't keep the books 

Do ShowAnAd 

return 

> 

// if we get here, we have no ads to show. Punt* 

return 

} 

// end ShowARerun 
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//////////////////////////////////// 

// Show a regular ad 
ShowARegularAd 

{ 

for regular ads [ in current block ] 
{ 

// has the ad been flushed? 
if ( ad. flushed ) 
try next ad 

// are we done showing this ad today? 

if { ad. number Shown?oday > ad.dayMax ) 

try next ad // this one's used up for the day 

// if in block, show ads only if it's their "turn" 

if ( ad. number ShownToday >« blockGoal ) 

try next ad // need to find a friend in this block 

// are we done showing this ad for ever and ever? 

if { ad.shownFor > ad . showForMax } 

try next ad // this one's used up forever 

// are we between the ad's start and end dates? 

if { ad. st art Date < the current date < ad.endDate ) 

try next ad 

// the ad is not supposed to run today 
// do we actually HAVE the ad? 
* if ( ad has not been downloaded ) 

{ 

ask for ad to be downloaded 

try next ad 

> 

// ok, we believe we should show this ad 
// we are now in regular state 
Do ShowAnAd 
return 

} 

// If we get here, we have failed to find a regular 
//ad. Go to runout 
Do ShowARunout 
} 

// end ShowARegularAd 



Fig. 15E 



//////////////////////////////////// 

// Perform necessary housekeeping when we're taking 
// down an ad 
AdEndBookkeep ing 

{ 

// In rerun state, we don*t do any bookkeeping 

if ( in RerunState ) 

return 

// Account for at most ad.showFor seconds, provided 
// we've shown the ad for at least ad.showFor seconds 
// Note that this means we don't charge for time beyond 
// ad.showFor seconds, which is important 
if ( ad.thisShowTime >= ad.showFor ) 
{ 

ad* number ShownToday += ad.showFor 
ad. shownFor++ 

// we do NOT reset thisShowTime here, we do it in 

/ / AdStartBookkeeping . Xt actually doesn ' t matter where 

// we do it, provided we are careful NOT to do it for 

/ / runout ads . 

> 

} 

// end AdEndBookkeeping 



Fig. 15F 



//////////////////////////////////// 

// Show an ad, including bookkeeping and block handling 
ShowAnAd 

{ 

// If the ad is in a block, notice that 

if ( it's in a "block" playlist ) 

{ 

if ( not currently in a block ) 
{ 

find ad in block with minimum numberShown 
make that our ad 

set blockGoal to minimum number Shown* 1 
} 

set current block to this playlist 

} 

// now do bookkeeping 
Do AdStartBookkeeping 
// and actually show it 
Do DisplayThatAd 

} 



Fig. 15G 



//////////////////////////////////// 

/ / Perform housekeeping when we put up an ad 

AdStartBookkeeping 

{ 

/ / In rerun state , we don ■ t do any bookkeeping 

if { in RerunState ) 

return 

// For regular ads 

if ( it's a regular ad ) 

{ 

ad* thisShowTinte = 0 
ad. lastShownDate = now 
} 
} 

// end AdStartBookkeeping 



Fig. 15H 
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COMBINED DECLARATION / POWER OF ATTORNEY 



ATTORNEY DOCKET NO.: PA000373 

AS BELOW NAMED INVENTOR, I HEREBY DECLARE THAT: This Declaration is of the following type: 

^ Original □ Supplemental □ Continuation-In-Part □ Divisional 

□ Continuation □ National Stage of PCT 

My residence, post office address and citizenship are as stated below next to my name: I believe I am the original, first and sole inventor (if only one 
name is listed below) or an original, first and joint inventor (if plural names are listed below) of the subject matter which is claimed and for which a 
patent is sought on the invention E-MAIL SOFTWARE AND METHOD AND SYSTEM FOR DISTRIBUTING ADVERTISEMENTS TO 
CLIENT DEVICES THAT HAVE SUCH E-MAIL SOFTWARE INSTALLED THEREON the specification of which: 

03 is attached hereto. 

I~l was filed on as Serial No. 

□ was amended on (if applicable). 

I~l was described and claimed in PCT International Application No. filed on and as amended under PCT Article 19 on 

I hereby state that I have reviewed and understand the contents of the above-identified specification, including the claims, as amended by any 
amendment referred to above. I acknowledge the duty to disclose information which is material to the examination of this application in accordance 
with Title 37, Code of Federal Regulations, Sec. 1.56(a). 

I;g|reby claim foreign priority benefits under Title 35, United States Code, Sec. 119 of any foreign application(s) for patent or inventor's certificate 
qrfpf any PCT International application(s) designating at least one country other than the United States of America listed below and have also 
id&tified below any foreign application(s) for patent or inventor's certificate or any PCT International application(s) designating at least one country 
cither than the United States of America filed by me on the same subject matter having a filing date before that of the application(s) of which priority 
irdlaimed. 

Priority Claimed 



(Country) (Application No.) (Day/Month/Year/Filed) (Yes) (No) 

I; hereby claim the benefit under Title 35 USC 120 of the United States application(s) listed below, and insofar as the subjecl matter of each of the 
clajjns of this application is not disclosed in the prior United States application in the manner provided by the first paragraph of Title 35 USC 1 12, 1 
acknowledge the duty to disclose material information as defined in Title 37 CFR 1.56(a) which occurred between the filing date of the prior 
application and the national or PCT International filing date of this application: 

:g 60/169,622 December 8, 1999 Pending 

(Filing Date) (Status) 

June 1, 2000 Pendi ng 

(Serial No.) (Filing Date) (Status) 

09/609,123 June 30, 2000 Pending 

(Serial No.) (Filing Date) (Status) 

I hereby appoint the following attorneys and/or agents to prosecute this application and to transact all business in the U.S. Patent and Trademark 
Office connected therewith: Russell B. Miller, Reg. No. 31,122, Gregory D. Ogrod, Reg. No. 30,880, Bruce W. Greenhaus, Reg. No. 37,339, 
Charles D. Brown, Reg. No. 28,285, Thomas R. Rouse, Reg. No. 40,793, Kent D. Baker, Reg. No. 38,822, Thomas M. Thibault, Reg. No. 42,181, 
Tom Streeter, Reg. No. 32,007, Christopher O. Edwards, Reg. No. 36,127, Pavel Kalousek, Reg. No. 44,178, Kyong H. Macek, Reg. No. 42,977, 
Byron Yafuso, Reg. No. 45,244, Raymond B. Horn, Reg. No. 44,773, Kevin J. Clark, Reg. No. 42,421, Sean English, Reg. No. 37,319, Roger W. 
Martin, Reg. No. 39,291, Sandip S. Minnas, Reg. No. 44,945, Michael D. Hartogs, Reg. No. 36,547, Philip R. Wadsworth, Reg. No. 29,219 and S. 
Hossain Beladi, Reg. No. 42,311, Albert J. Harnois, Reg. No. 46,123, Sandra L. Godsey, Reg. No. 42,589, George C. Pappas, Reg. No 35,065. 
Please direct all telephone calls to Philip R. Wadsworth at (858) 651-4404 and address all correspondence to: Sarah Kirkpatrick, Manager, 
Intellectual Property Administration, QUALCOMM Incorporated, 5775 Morehouse Drive, San Diego, California 92121-1714. 

I hereby declare that all statements made herein of my own knowledge are true and that all statements made on information and belief are believed to 
be true; and further that these statements were made with the knowledge that willful false statements and the like so made are punishable by fine or 
imprisonment, or both, under Section 1001 of Title 18 of the United States Code and that such willful false statements may jeopardize the validity of 
the application or any patent issued thereon. 



(Serial No.) 
60/209,392 
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Full Name of Sole or First Inventor 

Paul E. Jacobs 


Inventor Signature 


Date 


Residence 

9075 La Tolla Shores Lane, San Diego, C A 92037 


Citizenship 

United States of America 


Post Office Address 

9075 La Tolla Shores Lane, San Diego, CA 92037 


Full Name of Second Inventor 

Franklin P. Antonio 


Inventor Signature 


Date 


Residence 

2765 Cordoba Cove, Del Mar, CA 92014 


Citizenship 

United States of America 


Post Office Address 

2765 Cordoba Cove, Del Mar, CA 92014 


Full Name of Third Inventor 

Steven Dorner 


Inventor Signature 


Date 


Residence 

7 Montclair Road, Urbana, IL 61801 


Citizenship 

United States of America 


Post Office Address 

% Montclair Road, Urbana, IL 61801 


Etill Name of Fourth Inventor 

:;Jphn W. Noerenberg 


Inventor Signature 


Date 


Igsidence 

!;fc343 Fig Tree Street, San Diego, CA 92131 


Citizenship 

United States of America 


:P@st Office Address 

:l2343 Fi£ Tree Street, San Diego, CA 92131 


Full Name of Fifth Inventor 

Jeffrey K. Belk 


Inventor Signature 


Date 


-.Residence 

■13967 Arbolitos Drive, Poway, CA 92064 


Citizenship 

United States of America 


Post Office Address 

13967 Arbolitos Drive, Poway, CA 92064 


iPtdl Name of Sixth Inventor 

Benjamin P. Ogdon 


Inventor Signature 


Date 


Residence 

482 15 th Street, Del Mar, CA 92014 


Citizenship 

United States of America 


Post Office Address 

482 15 th Street, Del Mar, CA 92014 


Full Name of Seventh Inventor 

Jeffrey D. Beckley 


Inventor Signature 


Date 


Residence 

15696 Oakstand Road, Poway, CA 92064 


Citizenship 

United States of America 


Post Office Address 

15696 Oakstand Road, Poway, CA 92064 


Full Name of Eighth Inventor 

Alan Bird 


Inventor Signature 


Date 


Residence 

13757 Butano Way, San Diego, CA 92129 


Citizenship 

United States of America 


Post Office Address 

13757 Butano Way, San Diego, CA 92129 
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Full Name of Ninth Inventor 

Tohn D. Boyd 


Inventor Signature 


Date 


Residence 

4934 Via Lauiz, San Diego, CA 92122 


Citizenship 

United States of America 


Post Office Address 

4934 Via Lauiz, San Diego, CA 92122 


Full Name of Tenth Inventor 

TohnS. Purlia 


Inventor Signature 


Date 


Residence 

4090 Porte de Palmas, San Diego, CA 92122 


Citizenship 

United States of America 


Post Office Address 

4090 Porte de Palmas. San Diego, CA 92122 


Full Name of Eleventh Inventor 

William T. Rhodes 


Inventor Signature 


Date 


Residence 

.11 441 Eridanus Court, San Diego, CA 92126 


Citizenship 

United States of America 


H)st Office Address 

!;3il441 Eridanus Court, San Diego, CA 92126 


full Name of Twelfth Inventor 

fikvid T. Ross 


Inventor Signature 


Date 


Residence 

! d262 Carmel Valley Road, Suite A, San Diego, CA 92014 


Citizenship 

United States of America 


.Post Office Address 

"f)fO. Carmel Vallev Road, Suite A, San Diego, CA 92014 


jgull Name of Thirteenth Inventor 

■Matthew J. Dudziak 


Inventor Signature 


Date 


• fesidence 

13544 Ridley Road, San Diego, CA 92129 


Citizenship 

United States of America 



;Ppst Office Address 

d3544 Ridley Road, San Diego, CA 92129 



Charles D. Brown 
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